The N.I.G.E. Machine

Andrew Read

Table of Contents

[1. Introduction 3](#_Toc321927256)

[2. System Architecture 4](#_Toc321927257)

[3. 32-bit softcore CPU 5](#_Toc321927258)

[3.1. Design objectives and general features 5](#_Toc321927259)

[3.2. CPU specifications 6](#_Toc321927260)

[3.3. CPU operation 9](#_Toc321927261)

[3.3.1. Instruction encoding 9](#_Toc321927262)

[3.3.2. CPU design: the datapath and control unit 10](#_Toc321927263)

[3.4. Datapath of the parameter stack 11](#_Toc321927264)

[3.5. Datapath of the Return Stack 14](#_Toc321927265)

[3.6. The Control Unit 15](#_Toc321927266)

[3.6.1. The finite state machine 15](#_Toc321927267)

[3.6.2. Microcode 15](#_Toc321927268)

[3.6.3. Program counter 16](#_Toc321927269)

[3.6.3. Memory channels 17](#_Toc321927270)

[4. Other hardware components 19](#_Toc321927271)

[4.1. Interrupt controller 19](#_Toc321927272)

[4.2. Reset Controller 20](#_Toc321927273)

[4.3. Direct Memory Access (DMA) Controller 21](#_Toc321927274)

[4.4. Video controller 22](#_Toc321927275)

[4.5. RS232 controllers 24](#_Toc321927276)

[4.5. PS/2 controller 25](#_Toc321927277)

[4.7. System hardware registers 26](#_Toc321927278)

[4.8. Digilent I/O port 26](#_Toc321927279)

[4.9. PSDRAM 26](#_Toc321927280)

[4.10. SRAM 27](#_Toc321927281)

[5. CPU instruction set reference 28](#_Toc321927282)

[6. System software 37](#_Toc321927283)

[6.1 FORTH implementation 37](#_Toc321927284)

[6.2 Cross assembler 37](#_Toc321927285)

[6.1 FORTH word set reference 37](#_Toc321927286)

[6.3.1 CORE words 37](#_Toc321927287)

[6.3.2 CORE EXTENSION words 41](#_Toc321927288)

[6.3.3 FACILITY words 42](#_Toc321927289)

[6.3.4 FILE ACCESS words 42](#_Toc321927290)

[6.3.5 PROGRAMMING TOOLS words 42](#_Toc321927291)

[6.3.6 STRING words 42](#_Toc321927292)

[6.3.7 N.I.G.E. Machine specific FORTH words 43](#_Toc321927293)

[8. System memory map 46](#_Toc321927294)

[8.1 Overall memory structure 46](#_Toc321927295)

[8.2 System memory in SRAM 46](#_Toc321927296)

[8.3 hardware registers 46](#_Toc321927297)

[8.4 System memory in PSDRAM 47](#_Toc321927298)

[9. FPGA statistics and measurements 48](#_Toc321927299)

[9.1 Overall utilization 48](#_Toc321927300)

[9.2 Module level utilization 48](#_Toc321927301)

[9.3 Timing summary 48](#_Toc321927302)

[10. Design decisions 49](#_Toc321927303)

[10. References and acknowledgements 53](#_Toc321927304)

# 1. Introduction

The N.I.G.E. Machine is a complete computer system running on an FPGA development board. The system comprises a stack-based, 32-bit softcore CPU, video controller, I/O ports, RAM, and system software in the form of a FORTH environment. The system hardware is coded in VHDL and the FORTH environment is coded in the assembly language of the softcore CPU. All of the design for the CPU and most of the other components is original.

The N.I.G.E. Machine has been implemented and tested on a Digilent Nexys 2 development board with a Xilinx XC3S1200E FPGA with a clock frequency of 50 MHz. With a PS/2 keyboard and VGA monitor connected to the board the system is a fully operational native FORTH environment from power on.

The N.I.G.E. Machine’s intended applications are in four areas:

* Prototyping scientific hardware applications. The N.I.G.E. Machine is an open platform for bringing together hardware and software. It provides the flexibility of using VHDL to develop very specific custom hardware components and electronic interfaces, that are directly available within a local computer environment with all the interactive benefits of a FORTH interpreter and a compiler. This is intended provide interesting possibilities for developing one-off experimental apparatus.
* Micro-computer style programming on modern hardware. The 8/16-bit micro-computers of the 1980’s attracted enthusiasts because of their simplicity and direct access to hardware. At that time the bottleneck to developing interesting projects was the limited computing power. With modern computers, the bottleneck is the confusion that comes from multiple layers of software abstraction and legacy code. The N.I.G.E. Machine is a “pure-bred” descendant of the micro-computer concept in its usability and focus, but which also takes full advantage of modern advances in silicon computing power.
* Experimentation in a native FORTH environment. These days FORTH is usually only available either as a hosted application on a modern PC or within an embedded micro-controller that lacks the full scope of a micro-computer environment. The N.I.G.E. Machine is a stand-alone, native environment that provides alternative possibilities for FORTH development.
* Investigating tradeoff decisions and approaches in digital design. Begin implemented in VHDL, the N.I.G.E. machine is a living design that continues to iterate as problems are better understood and new ideas come to mind. In the future the N.I.G.E. machine will develop and improve as it is ported to new development boards and more sophisticated FPGA’s.

The purpose of this manual is two-fold. Firstly, to provide a sufficient description of the N.I.G.E. Machine to allow interested users to confidently program the system as a stand-alone micro-computer in FORTH. Secondly, to describe the N.I.G.E Machine’s main components with enough detail and clarity to guide those wanting to develop or extend the hardware in VHDL.

# 2. System Architecture

The N.I.G.E. Machine has been designed around an FGPA development board that can be thought of as providing facilities in three areas:

* The FPGA itself, in this case a Xilinx XC3S1200E, provides the following (a) soft logic elements into which all of the hardware design is encoded and placed, (b) static RAM (SRAM), 50Kbytes in 2K blocks that is used for SRAM system memory, stack memory, various buffers, and CPU microcode, and (c) facilities such as dedicated multipliers and carry logic that are used within the CPU datapath
* Pseudo Static Dynamic RAM (PSDRAM), 16Mbytes, in a separate I.C. on the development board. The PSDRAM provides additional data memory for and text and pixel graphics buffers for the video controller and other application uses
* Various connectors and associated circuitry, for example a VGA connector with a simple digital-to-analog converter, an RS232 D-Sub connector with appropriate voltage conversion, a PS/2 keyboard connector, etc.

The hardware components of the N.I.G.E. Machine are implemented within the FPGA as follows:

|  |  |
| --- | --- |
| **Component** | **Description** |
| 32-bit softcore CPU | Central processing unit of the N.I.G.E Machine |
| Interrupt controller | Prioritizes and schedules interrupt requests from other hardware units and interfaces them with the CPU |
| Reset controller | Responsible for timing the power-on and flash reset of all hardware units |
| Direct Memory Access (DMA) Controller | Interfaces the external PSDRAM and provides separate channels to all hardware units that require access, e.g. the CPU and video controller |
| Video controller | Drives a standard VGA display with both character/text graphics and pixel graphics |
| RS232 controllers, x 2 | One for general serial port access and one intended for interfacing with an external SD card reader/writer. Further RS232 ports can be added |
| PS/2 controller | Interface for a standard PS/2 keyboard |
| System hardware registers | Registers which govern the various hardware units are memory mapped into the CPU address space enabling their control via software |
| Digilent I/O port | Debugging facility for the flashing system software during development |

# 3. 32-bit softcore CPU

## 3.1. Design objectives and general features

The softcore CPU has been designed with two goals in mind: (a) usability and performance in a micro-computer FORTH environment, and (b) suitability for directly controlling embedded hardware. Key design features that resulted are as follows:

* Stack based CPU storage: two stacks (parameter and return) are directly integrated with the CPU and writable in a single cycle. There are no other registers
* Code density: CPU microcode allows almost all instructions are encoded in a single byte to maximizes code density
* Throughput: a 3-stage pipeline provides throughput of one cycle per instruction for most instructions
* Flexible memory access: separate instructions are available to read and write memory in byte, word, and longword format. Even address alignment is not required when accessing word or longword data in SRAM system memory (PSDRAM must be evenly addressed)
* Subroutine performance: a compound RTS instruction can be overlaid on top of most single byte instructions, saving one clock cycle on each subroutine return
* Deterministic execution: all execution is deterministic, including conditional branches (PSDRAM access through the DMA controller being excepted).
* Interrupt response time: typically 4 cycles only, including branching to the appropriate interrupt vector code (with no registers, save/restore of a register file is not required)

The design goals and hardware tradeoffs also resulted in some limitations. It is planned to address these with improvements in future versions of the N.I.G.E. machine. Current limitations include:

* Program memory space: the CPU is only able to execute instruction code residing within SRAM and cannot execute instruction code residing in PSDRAM. This limitation arose from the desire to maintain single cycle throughput and deterministic execution at all times
* Lack of floating point: there is no hardware floating point facility
* Blocking interrupts: the interrupt scheduler provides interrupt prioritization but once an interrupt is in progress it will block all other interrupts, even those of higher priority
* 32-bit operands for multiplication and division: the hardware multipliers in the fabric of the current FPGA are limited to 32-bit operands, although MULT produces a 64-bit result

## 3.2. CPU specifications

|  |  |
| --- | --- |
| **Item** | **Specification** |
| Stacks / registers | 2 dedicated data stacks: parameter and return. There are no other registers |
| Parameter stack width / depth | 32 bits wide, 512 cells deep |
| Return stack width /depth | 32 bits wide, 512 cells deep |
| Data format for memory access | Big-endian |
| Instruction size | Most instructions are encoded in a single byte. Otherwise up to 5 bytes including in-line literal data. |
| Instruction throughput | 1 cycle per instruction for most instructions |
| Instruction latency | 3 cycles for most instructions based on a 3 stage pipeline   * Read instruction from system SRAM * Decode microcode using control unit SRAM block * Compute and rewrite to the stack |
| Stack manipulation: 15 instructions | * **NOP** (no operation) * FORTH words: **DROP**, **DUP**, **?DUP** \*, **SWAP**, **OVER**, **NIP**, **ROT**, **>R**, **R@**, **R>**, * **LOADPSP** (load parameter stack pointer onto stack), * **LOADRSP**(load return stack pointer onto stack), * **SAVEPSP** (save parameter stack pointer from stack), * **SAVERSP** (save return stack pointer from stack)   \* instruction executes in 2 cycles |
| Math operations: 12 instructions | * **+**, **-**, **NEGATE**, **1+**, **1-**, * **ASL** (arithmetic shift left), **ASR** (arithmetic shift right) * **MULTS**\*, **MULTU**\*, Signed and unsigned hardware multiplication take 32 bit operands and produce a 64 bit result * **ADDX**, **SUBX** (add /subtract with carry), * **DIVS** \*\*, **DIVU** \*\*   Signed and unsigned hardware division take 32 bit operands and produce a 32 bit quotient and a 32 bit remainder  \* instructions execute in 5 cycles  \*\* instructions execute in around 40 cycles |
| Comparison operations: 11 instructions | * Bitwise equality tests: **=**, **<>**, * Signed comparisons: **<**, **>**, * Unsigned comparisons: **U<**, **U>**, * Comparisons with zero: **0=**, **0<>**, **0<**, **0>** * **FALSE** (returns zero) |
| Bitwise operations: 7 instructions | Boolean operations: **AND**, **OR**, **INVERT**, **XOR**  Shift operations: **LSL** (logical shift left), **LSR** (logical shift right)  Sign extension to 32 bits: **XBYTE**, **XWORD** |
| Memory operations: 6 instructions | * **FETCH.L**, **STORE.L** * **FETCH.W**, **STORE.W** * **FETCH.B**, **STORE.B**   The CPU is capable of addressing RAM in byte, word, or longword units. The CPU transparently differentiates between addressing on-chip SRAM and external SDRAM with separately optimized logic. SRAM access takes 2 cycles for bytes, 3 cycles for words and 5 cycles for long words. SDRAM access is via the DMA controller and will depend on the controller to respond with a data ready signal. The CPU utilizes a 16 bit wide DMA datapath for word and longword access and an 8 bit wide datapath for byte access.  No address alignment for word and longword access is required for on-chip SRAM access, but even alignment is required for external PSDRAM access due to the access characteristics of the PSDRAM module on the Nexys2 board. Violations do not result in an exception or failure but incorrect memory access results will occur. |
| Load literal operations: 3 instructions | * **LOAD.B** (alternative assembler mnemonic **#.B**) * **LOAD.W** (or **#.W**) * **LOAD.L** (or **#.L**)   The literal instructions load the sack with a big-endian inline literal value, zero extended in the case of #.B and #.W. The #.L instruction is 5 bytes in length and executes in 5 cycles, likewise the instruction length and duration for #.W and #.B is 3 and 2 respectively. The XWORD and XBYTE instructions can be used to sign extend word and byte literals as required. |
| Flow control: 6 instructions | * **JMP** (jump to the address on the parameter stack) * **BSR**, **JSR** (either branch or jump to subroutine) * **RTS** (return from subroutine) * **BEQ**, **BRA** (conditional and unconditional branches)   The JMP, BSR, and JSR instructions are single byte length and pop the top of the parameter stack as the next instruction address. In the case of JMP and JSR, this is an absolute address, in the case of BSR it is a relative offset to the current instruction address.  JSR and BSR also push the address of the next following instruction onto the return stack before making the jump or branch. RTS pops the return address from the return stack and returns execution to that point.  BEQ and BRA are 2 byte instructions. The branch offset is encoded as a signed (two’s complement) 14 bit number, giving a branch range of 8 Kbytes either forwards or backwards calculated from the second byte of the instruction. BEQ is a conditional branch which pops the top item from the parameter stack. The branch is taken when equal to zero.  Standalone flow control instructions generally take exactly two cycles to execute. For efficiency, an RTS instruction can be overlaid on the encoding of a single byte arithmetic instruction so that the total execution time for both operations will be two cycles only (e.g. DROP,RTS) |
| Exception handling: 3 instructions | * **TRAP** * **RTS\_TRAP** * **RTI**   The TRAP instruction is used to insert a breakpoint into a program that will cause the CPU to execute a subroutine jump to the TRAP vector. The TRAP vector code should be terminated with an RTS. Alternatively, if the trap vector code is terminated with an RTS\_TRAP then the CPU will return to the next instruction of the main program, execute it, and then execute a subroutine branch to the TRAP vector again. This feature is used for single stepping through a user application.  The RTI instruction is use to terminate the vector program code for external interrupt handlers. In addition to returning from a subroutine in the same way as an RTS instruction, the RTI signals to the interrupt scheduler that the current interrupt has been completed |
| Reserved: 2 instructions | Reserved instruction encodings could be used in future as headers for two byte instructions, allowing the CPU to include additional functionality such as 3D array calculations, floating point stack operations, or others. |
| Interrupts | The CPU supports hardware interrupts (in addition to the software TRAP instruction described above). When an interrupt trigger occurs the CPU completes the current instruction and then executes a subroutine branch into the interrupt vector table. Each interrupt trigger also supplies an interrupt vector number (1 – n) which determines the associated interrupt vector address. Entries in the interrupt vector table consist of 2 bytes BRA instructions that further vector to the interrupt handling code.  There is a BRA instruction at address 0x00 which is the power-on and reset vector, and a BRA instruction at address 0x02 which is the TRAP vector.  Assuming that the current instruction when an interrupt occurs is a single cycle instruction, then the interrupt response time will be 4 cycles only, including further branching from the interrupt vector table to the interrupt handling code. |

## 3.3. CPU operation

### 3.3.1. Instruction encoding

The default instruction size of the CPU is single byte in order to maximize code density. Where literal data is required as part of an instruction it follows in the succeeding bytes.

Encoding is as follows. Firstly, bit 7 identifies whether the instruction is a branch or an ordinary instruction. If the instruction is a branch then bit 6 specifies if the branch is conditional or unconditional. If the instruction is ordinary (not a branch) then bit 6 specifies whether a return from subroutine is to be taken along with the execution of the instruction.

|  |  |  |
| --- | --- | --- |
| **Bit 7** | **Bit 6** | **Interpretation** |
| 1 | 1 | Unconditional branch (BRA) |
| 1 | 0 | Conditional branch (BEQ) |
| 0 | 1 | Ordinary instruction plus return from subroutine (RTS) |
| 0 | 0 | Ordinary instruction |

For ordinary instructions, bits 5 – 0 are read as an integer in the range 0 – 63 that identifies the instruction in question. This is called the “opcode” in N.I.G.E. Machine’s documentation. For branch instructions bits 5 – 0 of the instruction are read as the high part (bits 13 – 8) of the branch address, with a following byte holding the low part (bits 7 – 0). Thus the interpretation of bits 5 – 0 of the instruction depends on the setting of bit 7 as follows:

|  |  |  |
| --- | --- | --- |
| **Bit 7** | **Bit 6** | **Bits 5 - 0** |
| 1 | x | High part of branch address |
| 0 | x | Opcode 0 - 63 |

Branches and load literal instructions are the only multi-byte encoded instructions. They are organized as follows:

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
|  | **Bits 5 - 0 of  1st byte** | **2nd byte** | **3rd byte** | **4th byte** | **5th byte** |
| **Branch** | 14 bit branch address  (big endian) | | - | - | - |
| **LOAD.L** | opcode | Longword literal (big endian) | | | |
| **LOAD.W** | opcode | Word literal (big endian) | | - | - |
| **LOAD.B** | opcode | Byte literal | - | - | - |

### 3.3.2. CPU design: the datapath and control unit

The CPU comprises a datapath and a control unit. The datapath holds the registers and computation components associated with the data held in the parameter and return stacks. The datapath is a passive entity in the sense that it does not contain any control logic or state information of its own. Essentially it includes a network of multiplexers and other switches that route data between registers and through computation components in various configurations. The behavior of the datapath at any moment is entirely governed by a set of external control signals feeding to it from the control unit.

The control unit is built around a sophisticated finite state machine (FSM) that is responsible for reading program instructions from system memory, decoding those instructions, and then setting the control signals to the datapath as appropriate for the execution of each one. The control unit is also responsible for adjusting the program counter (PC) so that program instructions are read from memory in the appropriate order including program jumps and branches, dealing with interrupts and other exceptions, and supporting data transfers between system memory and the data path.

3.4. Datapath of the parameter stack

The figure below illustrates the parameter stack datapath.

![](data:image/jpeg;base64,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P/8AKBb/APxVAHoFFef/APCJfEP/AKKf/wCUC3/+Ko/4RL4h/wDRT/8AygW//wAVQB6BRXn/APwiXxD/AOin/wDlAt//AIqj/hEviH/0U/8A8oFv/wDFUAegUV5//wAIl8Q/+in/APlAt/8A4qj/AIRL4h/9FP8A/KBb/wDxVAHoFFef/wDCJfEP/op//lAt/wD4qj/hEviH/wBFP/8AKBb/APxVAHoFFef/APCJfEP/AKKf/wCUC3/+Ko/4RL4h/wDRT/8AygW//wAVQB6BRXn/APwiXxD/AOin/wDlAt//AIqj/hEviH/0U/8A8oFv/wDFUAegUV5//wAIl8Q/+in/APlAt/8A4qj/AIRL4h/9FP8A/KBb/wDxVAHoFFef/wDCJfEP/op//lAt/wD4qj/hEviH/wBFP/8AKBb/APxVAHoFFef/APCJfEP/AKKf/wCUC3/+Ko/4RL4h/wDRT/8AygW//wAVQB6BRXn/APwiXxD/AOin/wDlAt//AIqj/hEviH/0U/8A8oFv/wDFUAegUV5//wAIl8Q/+in/APlAt/8A4qj/AIRL4h/9FP8A/KBb/wDxVAHoFFef/wDCJfEP/op//lAt/wD4qj/hEviH/wBFP/8AKBb/APxVAHoFef8A/Nwv/cqf+3dH/CJfEP8A6Kf/AOUC3/8Aiqx/Denazpnx1kh1zXv7aum8NF1uPsaW21PtIATahwcEE59/agD1iiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKAPP8A4p/8yV/2Ndj/AOz16BXn/wAU/wDmSv8Asa7H/wBnr0CgAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigArz/AP5uF/7lT/27r0CvP/8Am4X/ALlT/wBu6APQKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooA8/8Ain/zJX/Y12P/ALPXoFef/FP/AJkr/sa7H/2evQKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACvP/APm4X/uVP/buvQK8/wD+bhf+5U/9u6APQKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooA8/+Kf8AzJX/AGNdj/7PXoFeZfG6/Oj+G9A1cRCYadr1tdmLdt37FkO3ODjPriuM/wCGmv8AqUf/ACpf/aqAPoCivn//AIaa/wCpR/8AKl/9qo/4aa/6lH/ypf8A2qgD6Aor5/8A+Gmv+pR/8qX/ANqo/wCGmv8AqUf/ACpf/aqAPoCivn//AIaa/wCpR/8AKl/9qo/4aa/6lH/ypf8A2qgD6Aor5/8A+Gmv+pR/8qX/ANqo/wCGmv8AqUf/ACpf/aqAPoCivn//AIaa/wCpR/8AKl/9qo/4aa/6lH/ypf8A2qgD6Aor5/8A+Gmv+pR/8qX/ANqo/wCGmv8AqUf/ACpf/aqAPoCivn//AIaa/wCpR/8AKl/9qo/4aa/6lH/ypf8A2qgD6Aor5/8A+Gmv+pR/8qX/ANqo/wCGmv8AqUf/ACpf/aqAPoCivn//AIaa/wCpR/8AKl/9qo/4aa/6lH/ypf8A2qgD6Aor5/8A+Gmv+pR/8qX/ANqo/wCGmv8AqUf/ACpf/aqAPoCivn//AIaa/wCpR/8AKl/9qo/4aa/6lH/ypf8A2qgD6Aor5/8A+Gmv+pR/8qX/ANqo/wCGmv8AqUf/ACpf/aqAPoCivn//AIaa/wCpR/8AKl/9qo/4aa/6lH/ypf8A2qgD6Aor5/8A+Gmv+pR/8qX/ANqo/wCGmv8AqUf/ACpf/aqAPoCivn//AIaa/wCpR/8AKl/9qo/4aa/6lH/ypf8A2qgD6Arz/wD5uF/7lT/27rz/AP4aa/6lH/ypf/aq0vhv44PxB+MNzrH9nfYBBoBtfK8/zc4uFbdnav8AexjHagD26iiigD//2Q==)

The top-of-stack (TOS) and next-on-stack (NOS) storage locations are 32 bit hardware registers and the remainder of the parameter stack is implemented with a dedicated 2KB SRAM block. This SRAM block is dual ported and the second port is mapped to system memory where it can be accessed by the CPU. This is useful for implementing FORTH instructions such as PICK. The datapath is directed from the control unit via a 14 bit wide signal generated from control unit microcode that drive a set of multiplexers in the datapath to determine the data flow. The main multiplexers controlling the parameter stack are as follows:

* The multiplexer TOSn selects the value for the update of the TOS register from one of eight computation units: addition/subtraction, logic operations, multipurpose, comparison, multiply, unsigned multiply, divide and unsigned divide.
* The multiplexer NOSn selects the value for update of the NOS register from: TOS, NOS (i.e. itself, no-update), the item below NOS in the parameter stack RAM, and an arithmetic value from one of the computation units.
* The multiplexer PSPn is responsible for updating the parameter stack (PS) pointer, which is a 9 bit address signal spanning 512 \* 32 bit cells in 2KB SRAM. The PS pointer can be incremented (the stack grows by one item), decremented (the stack shrinks by one item), held constant or updated with the current TOS value. When the PS pointer is incremented, the current NOS item is written from the 32 bit register to SRAM. The opposite dataflow occurs when the PS pointer is decremented.

The eight multiplexed computation units attached to TOSn essentially form the arithmetic logic unit (ALU) of the CPU. Each computation unit is further directed by signals from the control unit microcode as necessary according to the functionality required by each function. Some of the computation functionality is provided by Xilinx CORE modules that often leverage special purpose circuitry available within the FPGA such as hardware multipliers and carry logic structures. The computation units are summarized below.

|  |  |
| --- | --- |
| **Computation unit** | **Available outputs** |
| ADDSUB | * **TOS** (no change) * **–TOS** (negate) * **NOS + TOS** (add) * **NOS – TOS** (subtract) * **NOS + TOS** (add with carry) * **NOS – TOS** ( subtract with carry) * **TOS + 1** ( increment) * **TOS – 1** (decrement)   The adder/subtractor is implemented using a XILIX CORE template that leverages special purpose carry structures on the FPGA. There is a carry flag within the ADDSUB unit that is not directly accessible to the CPU. This allows the N.I.G.E. machine to perform double precision addition and subtraction. The carry flag is only changed by one of the 7 addition or subtraction operations above and remains unchanged during the execution of all other instructions. |
| LOGIC | * **TOS AND NOS** (binary AND) * **TOS OR NOS** (binary OR) * **INVERT TOS** (binary NOT) * **TOS XOR NOS** (binary XOR) * **TOS LSL** (logical shift left 1 bit) * **TOS LSR** ( logical shift right 1 bit) * **TOS ASL** (arithmetic shift left 1 bit) * **TOS ASR** (arithmetic shift right 1 bit)   The logic computation is implemented in VHDL |
| MULTI | * **NOS** * **Parameter stack memory** (i.e. current third-on-stack) * **Top of Return Stack** * **Parameter stack pointer** (i.e. parameter stack count) * **Return stack pointer** (i.e. return stack count) * **XBYTE** (sign extension of TOS from 8 to 32 bits) * **XWORD** (sign extension of TOS from 16 to 32 bits) * **Memory data register** (either for load literal or fetch operations)   Multi is a general purpose multiplexer implemented in VHDL. |
| COMP | * **NOS = TOS** (Boolean equals) * **NOS <> TOS** (Boolean not equals) * **NOS < TOS** (Boolean signed less than) * **NOS > TOS** (Boolean signed greater than) * **NOS U< TOS** (Boolean unsigned less than) * **NOS U> TOS** (Boolean unsigned greater than) * **TOS = 0** (Boolean equals zero) * **TOS <>0** (Boolean not equals zero) * **TOS <0** (Boolean less than zero) * **TOS >0** (Boolean greater than zero) * **0** (zero, i.e. false)   The comparison unit is implemented using a XILINX CORE template with supporting logic in VHDL.The following inactive functionality is also available within the comparison unit but not accessible from the instruction set due to instruction set design tradeoffs.   * **NOS <= TOS** (Boolean less than or equals) * **NOS >= TOS** (Boolean greater than or equals) * **TOS <= 0** (Boolean less than or equals zero) * **TOS >= 0** (Boolean greater than or equals zero) * **0xFFFFFFF** (i.e. true) |
| M | * **NOS \* TOS** (signed multiply)   Signed multiply is implemented using an on-chip XILINX pipelined multiplier with 32 bit operands and a 64 bit result. It completes operation in 5 clock cycles. |
| UM | * **NOS \* TOS** (unsigned multiply)   Unsigned multiply is implemented using an on-chip XILINX pipelined multiplier with 32 bit operands and a 64 bit result. It completes operation in 5 clock cycles. |
| D | * **NOS / TOS** (signed divide with quotient and remainder)   Signed divide is implemented in logic fabric using a XILINX CORE template using 32 bit operands, a 32 bit quotient and a 32 bit remainder. It completes in 42 clock cycles. |
| UD | * **NOS / TOS** (unsigned divide with quotient and remainder)   Unsigned divide is implemented in logic fabric using a XILINX CORE template using 32 bit operands, a 32 bit quotient and a 32 bit remainder. It completes in 41 clock cycles. |

3.5. Datapath of the Return Stack

The figure below illustrates the return stack datapath.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAwgAAAIlCAYAAABxQN9LAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAAFxEAABcRAcom8z8AAGahSURBVHhe7b0xqC9HsqcpQ4Zo4yF4CJq2JK/NY2mbQcZxltfmNWVqBQNtXrONZxzjQY8jZDbPWV1nto0xBHJ6vGstcp4QPKdhxhC9jqyVHLGNYJbdilFFK2/erMrMyqyqyIzvD4dz7/lnZUZ8EVUVv8rKqjfe+Pnzh+Wf/5/Rn88CO/knBCAAAQhAAAIQgAAEIHABAaviQO26AAFD7BD4ehWPItY+CoSkh///d8e+s1NAAAIQgAAEIOCYgNVC3Kpd3lLlyZvDgb+Sgx4/jx6dxmcIQAACEIAABH4mYLUQt2qXt9xBIHiL+E+3HPKBAAQgAAEIQMAxAauFuFW7vKWK52LRq+9e/fa2b+MvBCAAAQhAYJOA1ULcql3eUslzsejV95fekhx/IQABCEAAAhB4lYDVQtyqXd7y58mbw4G/XgXCo+OY4zoEIAABCEAAAgsBq4W4Vbu8JQ0CwVvEWYPgL+J4DAEIQAACEIgIWC3ErdrlLYG8XkWXOHv13avf3vZt/IUABCAAAQhsErBaiFu1y1sqeS4WvfrOGgRvezn+QgACEIAABJhBIAcqCHCLUQWsSZo+TuIHbkAAAhCAAAQgcJCA1Sv1Vu06iHnYzRAIw4busOFeZ04OA2NDCEAAAhCAwGwErBbiVu2aLf45fzwXi1599+p3bl/gewhAAAIQgIAbAlYLcat2uUmM1VHPxaJX31mD4G0vx18IQAACEIBARMBqIW7VLm8JxC1G3iL+xhuP/lzGYwhAAAIQgAAEQgJWC3GrdnnLnlaB8M4C7IflR+MZ//7r8t1bAdTPo7bx99L0F8vPV0G7VJseceo5gyAcY98/2TAyZrDVroePqT56+n2WjfQLAQhAAAIQgMCJBKwW4lbtOjEUJrvuXSxK8ZsqeFVIfLF8/2YkGL5b/v/e+jcVB2G7D5fv4u16wOzpuwiE0MaUv3sMPu7hUGEfPf0uHJJmEIAABCAAAQhYImC1ELdql6XYXWFL72JxSyDI31NFvgoCFRXvL+1+XH4+uMD5nr7HAkHMF2ETih9pc9ZsSA0u1iDU0KItBCAAAQhAYEICVgtxq3ZNmAK7LknR2vOTEgh65XzrKnlYOGvbK267OVsgiNj5dvmR2ZEcgzgGZ82ayDiPPQNOXxCAAAQgAAEIjEfAaiFu1a7xItxm8RUCITcrkLrSLvlx9tX2swVC6FeOwZUCoaffbdnH1hCAAAQgAAEI3ELAaiFu1a5bgnTjoL2LxdQMQq44jgWC4NBtzhQKPX0XoRXeQqX2H7116swZhJ5+35i6DA0BCEAAAhCAwFECVgtxq3Yd5Tzqdr2LxV4CQXlqoX3GbEJP30UgaE7r7/CWqpxIEn9TfWhfPRdpswZh1L0VuyEAAQhAAAKdCFgtxK3a1Qn7MN1IUdrz07oGIWVLSXF9xIfeAmGviGcNwpEIsQ0EIAABCEAAAqcQsFqIW7XrlCAY7vQKgSDui3AoeYrRrAJhj0HKZ24xMrzTYBoEIAABCEBgdAJWC3Grdo0e71r7e15F1yI49QSi+J58aauPOA1vH0oVxiIuRrjFKHcbUM17EBAItZlMewhAAAIQgAAEiglYLcSt2lUMdpKGVwkEwZV663JKTDwtbcP7+XOF99FQ9PRdbC6xM35LtNhwxSNdQ0asQTiaMWwHAQhAAAIQmISA1ULcql2ThL3YDSlsvX56CoSRGD6OZCy2QgACEIAABCDQn4DVQtyqXf0jYLtHBILt+JxhnVdhdAZL+oQABCAAAQgMScBqIW7VriGD3GC052LRq+9e/W7YTdgUAhCAAAQgMBcBq4W4Vbvmin7eG8/FolffWYOQ3y9oAQEIQAACEJiagNVC3KpdUydDwrknbw4H/noVCI+OY47rEIAABCAAAQgsBKwW4lbt8pY0CARvEf/pmMAHAhCAAAQgAAHHBKwW4lbt8pYqnotFr7579dvbvo2/EIAABCAAgU0CVgtxq3Z5SyXPxaJX31mD4G0vx18IQAACEIBARMBqIW7VLm8JxC1G3iL+xhuP/lzGYwhAAAIQgAAEQgJWC3GrdnnLHgSCt4izBsFfxPEYAhCAAAQgwAwCOVBBwOttNoLIq+9e/a7YLWgKAQhAAAIQmJuA1Sv1Vu2aOxte9e73a5GsseD3z0/98sLij54SHl8hAAEIQAACEPiJgNVC3KpdnvJGFqt6KYTxMx3rv3lKeHyFAAQgAAEIQACBQA7sE3i2CoRvl99vAcsVgc/X2H/qymuchQAEIAABCECAGQRyIEvg67VQfJ5tSYNZCDyuMZfZg1/O4hR+QAACEIAABCBQTsDqrTxW7SonO0fLZ2uxyCzCHPEs8UJFIbMHJbRoAwEIQAACEJiQgNVC3KpdE6ZA1iVmEbKIpmmggpDZg2lCiiMQgAAEIACBegJWC3GrdtUTHn8LZhHGj2GpByoGn0o3oB0EIAABCEAAAvMRsFqIW7Vrvgwo84hZhDJOI7dCCI4cPWyHAAQgAAEIdCRgtRC3aldH9EN1RfE4VLgOGYsIPISNjSAAAQhAAALzEbBaiFu1a74MKPeIxavlrEZriQAcLWLYCwEIQAACEDiRgNVC3KpdJ4bCfNdaRLKA1Xyoqg1k9qAaGRtAAAIQgAAE5iVgtRC3ate8mVDm2ZdLM4kNj8As4zVCK2YPRogSNkIAAhCAAAQuJGC1ELdq14WhMTnUwyoQmEUwGZ5DRjF7cAgbG0EAAhCAAATmJWC1ELdq17yZUO7Z58wilMMy3pLZA+MBwjwIQAACEIDAHQSsFuJW7bojRtbGZBbBWkSO2fPWstlfVrH3/FgXbAUBCEAAAhCAwIwErBbiVu2aMQeO+MQswhFqtrYRUSD72bfLj4gFPhCAAAQgAAEIQOB/ErBaiFu1i7T5icDDmjusRRgzI0QQiDCQ/eyjMV3AaghAAAIQgAAEziJgtRC3atdZcRixX2YRRozaTzY/X8WBLFDmAwEIQAACEIAABF4hYLUQt2oX6fMzgYe1yGQWYaysCGcPno1lOtZCAAIQgAAEIHAFAauFuFW7rojJSGNYnkVQ2zSXwt+fZCA/reIn3ObjkQKzY+vz1TdmDyYJKG5AAAIQgAAEehOwWohbtas3/9H7C2cR5N9WPr9YDPkqUeSHBf93y/fvRQbntvvAioMH7WD24CA4NoMABCAAAQh4ImC1ELdql6fcKPX1T2shLlfsrXzCQj8u6t9fjPxxtfmL5febgdFP69//uvwOn+zzzvL/H5af0QXC89U/Zg+sZCp2QAACEIAABAwSsFqIW7XLYAhvN+mXiwWyDkFi9nC7NT8ZsCcQ5HsVCbEQ0NuSZrmdKAwHswdGkhMzIAABCEAAAtYJWC3ErdplPZ532ffpKhCszCLkBILOCLQIBBUZup4hXvNgbbbh+RojZg/u2ksYFwIQgAAEIDAIAauFuFW7Bgnr5WZam0XICYQP12K59BajFFAVCP95+VJuP0othrYyE8HsweW7BANCAAIQgAAExiVgtRBPFVv8LV2EWuNiYRahdA1CXMDrzIIy3Svww7UM0j5sq7MJsQC560jxe2YP7kLPuBCAAAQgAIHxCCAQxii6rYmALXv+x1qIPty8K+SeRhQX9KG5sUiQtqnHooYCIb6dSPtIPSnpajTh7M7j1YMzHgQgAAEIQAAC4xGwLhDGI+rbYitrEXICoWR9QDxDEK9X0O9TswQ6vgWBYCUmvvcMvIcABCAAAQgMRACBMFCwBjDVylqErVuMntYZDsn7EpEgyHW9gmwTioERBIKVeAyQupgIAQhAAAIQgIASQCCQC70JWLhivbcGQUVCzfoAFQPhjMAIAsFCLHrnF/1BAAIQgAAEIHAyAQTCyYAddm/hqvWeQAjXGJTOIqTWFFgXCBbi4DD9cRkCEIAABCAwPgEEwvgxtOjBHxajJLe+vMm43GNOdRYhtfg4ZfKIMwjMHtyUfAwLAQhAAAIQGJ0AAmH0CNq0/+7n7ucEwl7Bv/fo01HWIDB7YHO/wCoIQAACEIDAEAQQCEOEaUgjn6+zCHe8uTcnEMLvVRDETy2KH+U60lOMmD0YcpfBaAhAAAIQgIANAggEG3GY0Yo7ZxFyAkF4p96mnHoHQu49CNYec8rswYx7Ez5BAAIQgAAELiSAQLgQtsOh7pxFcIj7f7rM7IHXyOM3BCAAAQhAoBMBBEInkHSTJHDnLILHkLy7OP239efXHgHgMwQgAAEIQAAC7QQQCO0M6WGfALMI12XI58tQsk/LLAIfCEAAAhCAAAQgcIgAAuEQNjaqIMAsQgWshqYPqziQGQRZh8AHAhCAAAQgAAEIHCKAQDiEjY0qCTxfi9c7nmhUaeqwzZk9GDZ0GA4BCEAAAhCwRaCHQAifGCP9pZ4VX/rGWqXTwy5bpH1bwyzCufF/WAUYswfncqZ3CEAAAhCAgAsCrYV46tnxoUBQ8VD6xloEwrxp9ztmEU4LLrMHp6GlYwhAAAIQgIA/Aq0CQQqT75af91Z0T9EMgvxZ2qSeFb9Hu9Uuf5Ecw2O5xUhiK2KBTx8CDytTZg/68KQXCEAAAhCAgHsCLYW4vlRK30QrMFMCQf4Wv4U2B77FrlzffH8fgWdrMfvt8ltuO+LTToDZg3aG9AABCEAAAhCAQECgpRBHIJBKRwjoLMLzIxuzzSsEHlbBxewBiQEBCEAAAhCAQDcCLQIhtb7gabEstQaBW4y6hWz4jp6tRS2zCO2hZPagnSE9QAACEIAABCAQEWgRCNKVCALpQ28zigWCFjDhbUglQWi1q2QM2txHgFmEdvYPgdDivQftPOkBAhCAAAQgAIGVQGshHj/iVPsLf9fOHohprXYRYNsEngXFLWsRjsVKxffzY5uzFQQgAAEIQAACEEgT6FWIpx53Kn3Xvv9ArexlF3G3S4BZhOOxQWAdZ8eWEIAABCAAAQhkCFgtxK3aRUL1I0CRe5wl4uo4O7aEAAQgAAEIQACBQA4YJqCFburWNP728612KRYs8jac2JgGAQhAAAIQGJmA1Sv1Vu0aOdYWbf/tYtT3yw9ioI6BPNb0I4sBxSYIQAACEIAABMYnUFOI66LII8UcL0obP1e8eVCzb3hjg78QgAAEIAABCExMoKYIemq40lv7JKMauyYOD67dSIAcvBE+Q0MAAhCAAAQgcB+B1iJIn170ScIFfQRq7eyBdNVq131EGXkWAuTgLJHEDwhAAAIQgAAEqgi0FkFy29He7EDqbcslBrbaVTIGbSCwR4AcJD8gAAEIQAACEHBJoKUIemch9sPyk3tL8tPSpnYWocUul4HE6e4EyMHuSOkQAhCAAAQgAIERCLQUQSoQUrcXhb7LLAMCYYRswMaQQMu+AUkIQAACEIAABCAwLIHWIkifbLQlEnLfb4FrtWvYgGC4GQLkoJlQYAgEIAABCEAAAlcSaC2CdBZh79Gn3y0OvVfpVKtdlcPRHAKvESAHSQoIQAACEIAABFwS6FUEfbjQS4mE3O1HzCC4TLshnO61bwzhLEZCAAIQgAAEIAABJWC1CLJqF5njhwA56CfWeAoBCEAAAhCAQEDAahFk1S6Sxw8BctBPrPEUAhCAAAQgAIETBELqFqMjaw+sz2yQPH4IIBD8xBpPIQABCEAAAhDoKBD0RWh7i5SPrEOgOCNN7yZADt4dAcaHAAQgAAEIQOAWAq1F0NNitfSReptyKB4+qPSu1a7K4WgOgdcIkIMkBQQgAAEIQAACLgm0FEEqAFLiQGGWtEmBb7HLZSBxujsBcrA7UjqEAAQgAAEIQGAEAi1FEG9SHiHC2HiUQMu+cXRMtoMABCAAAQhAAAK3E2gpghAIt4cPA04k0LJvnGgWXUMAAhCAAAQgAIFzCbQUQSW3D5W0SXnYYte5xOjdCwFy0Euk8RMCEIAABCAAgVcItBZB+njT3CLljyu5t9pVORzNIfAaAXKQpIAABCAAAQhAwCWBHkXQ5wu5vcec7i1i3oLewy6XAcXpbgTIwW4o6QgCEIAABCAAgZEI9CqC3l+c/jEhFGpnDpRdL7tGigW22iJADtqKB9ZAAAIQgAAEIHARAatFkFW7LgoLwxggQA4aCAImQAACEIAABCBwPQGrRZBVu66PECPeRYAcvIs840IAAhCAAAQgcCuB1iJIby36JOGFPsHor8t3b1V62WpX5XA0h8BrBMhBkgICEIAABCAAAZcEWosgWaC8JwD2BMQe8Fa7XAYTp7sSIAe74qQzCEAAAhCAAARGIdBSBNW8KK32SUYtdo3CHjttEyAHbccH6yAAAQhAAAIQOIlASxGkAiH3pKKnzCxDyrUWu05CRbfOCJCDzgKOuxCAAAQgAAEI/ESgpQgqeUtySRsEAtlokUDLvmHRH2yCAAQgAAEIQAACRQRaiyCZHZA+tm4h0peopRYx7xnYaleR8zSCwA4BcpD0gAAEIAABCEDAJYHWIkhnCLSf1G+eYuQytYZ3unXfGB4ADkAAAhCAAAQg4JNAryLow3UmIRYIufUJW9R72eUzqnjdgwA52IMifUAAAhCAAAQgMBwBq0WQVbuGCzAGHyZADh5Gx4YQgAAEIAABCIxMwGoRZNWukWON7XUEyME6XrSGAAQgAAEIQGASAr2KoNQtRt8tjN47yKmXXQeHZzMIND3hC3wQgAAEIAABCEBgWAKthXjJIuXaJxgJzFa7hg0IhpshQA6aCQWGQAACEIAABCBwJYHWIuhpLeZTjzkNxcMHlU612lU5HM0h8BoBcpCkgAAEIAABCEDAJYGWIqjkJWglbVLgW+xyGUic7k6AHOyOlA4hAAEIQAACEBiBQEsR9M7i4A/LT+4WInlZWu27EFrsGoE7NtonQA7ajxEWQgACEIAABCBwAoGWIgiBcEJA6NIMgZZ9w4wTGAIBCEAAAhCAAARqCbQUQSW3D5W0SdncYlctA9pDgBwkByAAAQhAAAIQgMBKoLUQ18eb5hYp175RudUuAgyBVgKag09LR/zAgBwgB8gBcqB3DvxuOb+81XqyYnsInEGgRyEuawy0n9TvlHjI+dLDrtwYfA+BPQLfZvJ6L+f5bv+YAB/4kAPkADnwUw7IhVY+EDBHoFch/v7i2Y+Jgqp25kAB9bLLHHAMGobAIzMHzJyQA+QAOUAOnJQDX68100fDnBUx1BUBq4W4VbtcJQfOQgACEIAABCBwCoHPEAincKXTTgRaCnFdgFz7CNMS01vsKumfNhCAAAQgAAEIQOAuAgiEu8gzbhGBlkK89DGnRYZEjVrsOjIe20AAAhCAAAQgAIGrCCAQriLNOIcItBTizCAcQs5GEIAABCAAAQg4J4BAcJ4A1t1vEQjimy5O7n2bUatd1rljHwQgAAEIQAACfgkgEPzGfgjPWwpxnUEoeVRZrYBosWsI8BgJAQhAAAIQgIBbAggEt6Efw/GWQlzXICAQxog1VkIAAhCAAAQgYIMAAsFGHLBig0CLQDgTqlW7zvSZviEAAQhAAAIQ8EEAgeAjzsN6abUQt2rXsIHGcAhAAAIQgAAEzBBAIJgJBYakCFgtxK3aRRZBAAIQgAAEIACBVgIIhFaCbH8qgdZCXJ9i9EnCypbHoLbadSo0OocABCAAAQhAAAINBBAIDfDY9HwCrYX454uJe08o2hMQe9612nU+OUaAAAQgAAEIQAACxwggEI5xY6uLCLQU4qVvUhYR8cXy82aFTy12VQxDUwhAAAIQgAAEIHA5AQTC5cgZsIZASyGuAuHjzIBPy/e8B6EmKrSFAAQgAAEIQGBmAgiEmaM7gW8tAkHXGOzNDpS0SWFssWuCsOACBCAAAQhAAAITE0AgTBzcGVxrLcRldkD62BIJcnuRfJ9axLzHr9WuGWKDDxCAAAQgAAEIzEkAgTBnXKfxqrUQ1xkC7Sf1u/b2IoHbatc0AcIRCEAAAhCAAASmI4BAmC6kcznUqxD/MCjqQ5GQW5+wRbOXXXNFC28gAAEIQAACEJiBAAJhhihO7IPVQtyqXROnAq5BAAIQgAAEIHARAQTCRaAZ5hgBq4W4VbuOUWYrCEAAAhCAAAQg8DMBBALZYJpATSGujzXVNQX6/731B/pd7TqEGrtMA8Y4CEAAAhCAAAQgEBFAIJASpgnUFOIIBNOhxDgIQAACEIAABAYhgEAYJFBezawRCFcysmrXlQwYCwIQgAAEIACBOQkgEOaM6zReWS3Erdo1TeBxBAIQgAAEIACB2wggEG5Dz8AlBKwW4lbtKmFKGwhAAAIQgAAEILBHAIFAfpgmYLUQt2qX6WBiHAQgAAEIQAACQxBAIAwRJr9G1hbiTwuqkqcWxW14ipHfHMNzCEAAAhCAAAReJYBAICNME0AgmA4PxkEAAhCAAAQgMCEBBMKEQZ3JpRaB8PGJIGrtOtEUuoYABCAAAQhAAAJdCSAQuuKks94EjhTiT4sR4S1EXyz/f7OzYUfs6mwC3UEAAhCAAAQgAIFTCCAQTsFKp70ItBTiqTcpf9DJsBa7OplANxCAAAQgAAEIQOAUAgiEU7DSaS8CvQrxz6NZhU8aDexlV6MZbL4Q+Hr5kQPZR0GMvfz//3Hq+3936rfkuNeYP3K0gwAELiWAQLgUN4PVEuhdiH8YCYXvlv+/V2tU0MeBTdmkMwHJEa8fr7579Vvy3KvvXv32emzD7/sJIBDujwEW7BDoLRB0qPj2Ix5zOm4aPo1rerPl3zT3MGYHnotFYj5mzmI1BEYjgEAYLWLO7D1LILy/cPwxmAlAIIybWJ4Fwotxw9ZkudciWaB5jfnLpoxhYwhAoJYAAqGWGO0vJdBbIEgxGT7hSP595HGove26FOpkg3m+muzVd69+y67r1ffHyY5buAMB6wQQCNYj5Ny+HoV46mlGtTMGcRh62OU8tN3c91oweS4WiXm33WeYjjzHfJggYehUBBAIU4VzPmdaCvF4QfLR2YIU1Ra75ovSvR7JrJDXj9dbbTwXi8Tc696O3xC4lgAC4VrejFZJoLYQ/8XS/1fLT3gbUetsAQKhMmgXN/csEF5czNrKcF6LZOHvNeasQbCy92GHFwIIBC+RHtTPWoEgxaJuc2RtQSmmWrtK+6VdPQHPV5O9+u7Vb9k7vPr+WH9oYAsIQKCBAAKhAR6bnk+gthAPBUI4i5D7d+0sQ61d55PyO4LXgslzsUjM/e3vnmPuL9p4bIEAAsFCFLBhk0BtIY5A8JdMEnOvH6+32nguFom5170dvyFwLQEEwrW8Ga2SQK1AqOz+cHOrdh12aOANPQuEFwPHrcV0r0WyMPMac9YgtOwxbAuBegIIhHpmbHEhAauFuFW7LgyNmaE8X0326rtXv2Wn8+r7o5kjDoZAwAcBBIKPOA/rpdVC3Kpdwwa6wXCvBZPnYpGYN+wwg27qOeaDhgyzByeAQBg8gLObb7UQt2rX7PmQ8u/pBqdlzHDh+yc32CBD3n2rzfuLDT8uP1f7b6VYvMP/1pinXhwZ5nL8wIbPo1xPPdAhfrx07UMfSnYfKzEvsZU2EJiBAAJhhihO7IPVQtyqXROnwqZrVwsEGe+75ee91SItuK4ukmX4FzcGPBRJV/veWiT3wHaX/71jLgIgFT/N6y+W798MgEn7MP9VHITt5CWV8XatzFmD0EqQ7SFQRwCBUMeL1hcTsFqIW7Xr4vCYGO7KK4taNMXv2JCCKCyargJzpe+hT/qW8g+WP24VmGcyuMtv9elO/3v7vhU/+XuqyFdBoKJCZ1EkF878PJ7ZOX1DAAKvEUAgkBSmCVgtxK3aZTqYJxnXu2DaM1OKoW+XH5090LZXFUmxbVf6vsVlZoFQciX8av97xzxl/5YQ1hx4Wv6htxFdNYPW2++TDkd0C4FpCCAQpgnlnI5YLcSt2jVnFux7JcXKVZ+tmQItks6+ihr7aeFWm6sLZGFwVbFoUSD0jnkqfjnBG+8Hsg9KTM5Ye6A5f1XMrzqWMA4ErBNAIFiPkHP7rBbiVu3ymC6WBEJ869HZ8Xhx9gAF/d8hEHoXyVtuWhQIvWPeQyAIPxUVZwmFlwW5SBMIQKAfAQRCP5b0dAIBq4W4VbtOCIH5Lq+8smhtBuFs3/XKsOZ7ajHrHQLhTL9jn9V3+Z26J/9q/3v73ksg6IFChULv2YRH80ciDITAXAQQCHPFczpvrBbiVu2aLgEKHOpdMO0NyRqE1+lcXSCLBVfF3OIMQm/fU/GrWYOQ2l9ytygV7NavNent9xEb2AYCngggEDxFe0BfrRbiVu0aMMTNJssV36s+W4WT2ND7immJT1fdarNnCwLh2vdA9I75Vvzk7yVPMUIglOyptIHAeAQQCOPFzJXFVgtxq3a5So7V2SsFggwphVMoBvRq6dXrD8SWFwYCfodA6F0kb2G0OIPQO+Zb8Uu9BE4fcRrmf4pRvI/0SNOXPTqhDwhAoJgAAqEYFQ3vIGC1ELdq1x0xunvMO249kAJIc0B+3yEOhPsdvsu4+h6AkIH8+6pZlLv81ly/0//evu8JvNRbl1PrUESkh7nQ+yVpwv3x7gMN40PAGQEEgrOAj+au1ULcql2jxbeHvb0Lph42XdWHV9+9+n2nKLwqp7fG8Rzzu9kzvk8CCASfcR/Ga6uFuFW7hglsR0Pl6qXXz1W32ljj67lYJObWshF7IDAnAQRCXVy3Zpa/W7qJX65a13Nda70VVM6TV7+bqc7SxtZWC3GrdjXiHnJzzwLhxZARazfaa5Es5LzG/GV72tADBCBQQQCBUAFraSq1SHzbrf7/SpHQ8qhpFTmpW0nraFzQ2mohbtWuC0JibgjPV5O9+u7Vb9n5vPr+aO7Ig0EQmJsAAqEuvrKeK75qH67jumutYo0XKnJGsPXvaqzGwSvaIhCuoFw2hteCyXOxSMzL9o2ZWnmO+UxxxJdxCCAQymOlt/WkZgpUOIxQdIutV852lBNOtLRaiFu1qwn2oBuL4vX68XqrjedikZh73dvxGwLXEkAglPPW23riJ7jl1gPoFXutKfeeBKhCQ9pqES/bxwX91m1C8VjhbURh3+FtUil7SmwOX5YZrs3oKpKsFuJW7SpP53laehYIL+YJY5UnXotkgeQ15i+rMoTGEIBAKwEEQjnBVFEeioM94RAW5PLvuChPPW56r4jXAj4sxrcEgLbZ+j60O/QnZ7Pa8K+LP2FbBEJ5TtGyAwHPV5O9+u7Vb9ldvPr+2OFYQRcQgEA5AQRCOav4qnpYFKfeC6MFeSwG9O/h04f0b1vFety/tA9nFVKzGyI6/q/lJ3y6Um6B8hGbhcNpC56tXqm3ald5Os/T0mvB5LlYJObz7L+lnniOeSkj2kGgJwEEQjnNrSvwqceMaiG+d/uOXmnfunVJLCt9232qXcozFTmpq/w1NoczDaeJAy2ALJ4YEAjlO87ZLSWpvX683mpj8ZhwVQ4S86tIMw4EfBNAIJTFP7VAWYvyvUXLsXjQIjzcZq9oT32ntyOFswrhLUp7b7mPZx5C71MzG/J9ymYd7/TFzlYLcat2laXzXK08C4QXc4Wy2BuvRbIA8hrzl8XZQUMIQKAHAQRCGUUtiEtuF8qtJ5DaUq/g7z0ZSSxLFfRbtwnF48ZX9nWs1KxGjc1iV+mMRRndnVZWC3GrdjUDH7ADz1eTvfru1W/ZPb36/jjgsQmTITAyAQRCWfS2ivLU37V41hoy/B1f3d8SHmLV1ndywTQUGbEH4fjhrUSpmQfdtsZm2SZnQxnVglZWC3GrdhUgnarJ83VnSO1s/G37rY6wgc2IOTDVwQtnIGCcAAKhLEBbBXFq/cDemoJ4tD2BoLf85BYopzxICZe9Bco1Nst4W7cjldGsaGW1ELdqVwXaKZp+iUDYfLX7iAUgNiNctnLg/53iiIUTEBiHAAKhLFZbBXHqXvy9ol+ERnjrT3hrj65XiB81GrZP3SYktsWLjtXe8O97AqHG5r1blcpoVrSyWohbtasC7RRN3128+GYVCV8vv9+ewiucgAAE3loQ/Hndt79ffj+ABAIQuJQAAiGPe2+dQFjgl7yTIHVrkBbz4YUTWfz7z+uxce82ob33FsQzD+HLzGSseIFxyg61qfRWpTzNyhZWC3GrdlXinaI5ImGKMOIEBP5OAHFAMkDgfgIIhHwM9u7d33uL8tNa4IeFf+rxonGRr4W9FOxxEZ9aHJxaYLz16NFQBKSedlRi82ULlCU0Vgtxq3bl03nOFoiEOeOKV/4IIA78xRyPbRJAINiMy6W38dhE8JNVVgtxq3ZZjuXZtiESziZM/xA4lwDi4Fy+9A6BGgIIhBpa/dvq1f/4fQl6Jf/Ul5D1d6d/j1YLcat29Y/AWD0iEsaKF9ZCQAkgDsgFCNgigEC4Nx57jxdNva/gXmtvGN1qIW7VrhtCZG5IRIK5kGAQBHYJIA5IEAjcQ+A3y7CyQDX12RMIss8+X37kfMvnPALx4mGpPd3PHChuq4W4VbvOS9OxekYkjBUvrPVLAHHgN/Z4fj+Bl4sJUs88S5iyJxD+sG4nbfhA4BYCVgtxq3bdEiSjgyISjAYGsyCwEkAckAoQuJfA87XQ/3b5Lftj+NkSCL9cGv1t3e6395rP6J4JWC3ErdrlOVdSviMSyAgI2CSAOLAZF6zyRUD2w7+sxf7vCwWCPg5TfvOBwG0ErBbiVu26LVCGB0YkGA4OprkkgDhwGXacNkpAZgGkppFZAZkd0E9qBuExaCvnVj4QuI2A1ULcql23Bcr4wIgE4wHCPDcEEAduQo2jAxHQWYE/ZQTC16tAkDUIfCBwKwGrhbhVu24NlvHBEQnGA4R50xNAHEwfYhwclICcH3VdgTzZSD7xDMLzVRyk1isM6jZmj0zAaiFu1a6RY32F7YiEKygzBgReJ4A4ICsgYJuAPplIZgligSC3HokwkNpn67Gotr3DuukIWC3Erdo1XQKc4BAi4QSodAmBHQKIA9IDAvYJyH6qIuB3y7/DGYRPV3HwpX03sNALAauFuFW7vORFq5+IhFaCbA+BMgKIgzJOtIKABQL6Yi4RCrIeQWodEQd6+9GDBSOxAQJCwGohbtUusqacACKhnBUtIXCEAOLgCDW2gcC9BF4GtZc+3Uh+//FesxgdAq8SsFqIW7WL/KkjgEio40VrCJQSQByUkqIdBGwReIgEgtQ73y8/4SNQbVmMNS4JWC3ErdrlMkkanUYkNALc2Fwfm6f7Svj7k8yQT4kT1MfRNr9Y/v9Vop2O88E5btFrAQHEQQEkmkDAMAFdc6DH0+eGbcU0pwSsFuJW7XKaJs1uIxKaEb7SQa54l/3nu+XnvYaiv2SMnBDp6zW9CQHEAXkAgfEJhE8tkqcayX7NBwKmCFgtxK3aZSp4gxmDSOgXsLB4j6/kv78M8+PyI/vQF8vPm8GwT+vf/xqdkN5Z/v/D8hP2pWOkhIb2I2Mwk9AvrrmeEAc5QnwPgXEIyJOM5Bgqb1rmAwFzBKwW4lbtMhfAwQxCJPQJ2J5AkBFUJMRCQG9Lim8nSlm1JxCkvYoEZhH6xDTXC+IgRyj/vT6HPnVbHn/7+aElsIAFOeAzBz4LD6NWC3GrduVPQbTIEUAk5Ajlv88JBJ0ROFMg6OP6wlkKFSYqGuJ1Esw25GObaoE4OMYt3oqix2fRQ9yJOzlQngN/P25aLcSt2tXnNEUviIS2HMgJhFTxHl71j4XDkRmEPYHwn5cO5Zal1EG5ZPaijc5cWyMO+sWT80o/lvQEAQjMReC146PVAyZqr1ztzcBKFmm9Pde+dqo3pWsQ4mJcZxY0Z/aK9dwtRjo7EN5iFK5/kDHC/rV9vC7iVFCDd4446BtAq+e7vl7SGwQgAIF6AgiEjauaMxTZo/uASCjfoUueMLRV/MciQfImtY5gTyBosR8vYA4FQnw7kY6bWvRc7rmfloiD/rFGIPRnSo8QgMAcBIYTCHNgx4s9Au8uX36zCjdEQlmu5ARCyb3+8dX++Laj3BjxDIFYrn2mZglyMxJlnvtohTg4J84IhHO40isEIDA+AQTC+DGc0gNEQl1Yt24xelqFluzoJSJBRtW1BLJNWNjvCYSt24QQCHVxTLVGHLQz3OoBgXAeW3qGAATGJoBAGDt+U1uPSCgP794aBBUJNff6a2Ef3v5z5Io/AqE8hoiDNlZHtkYgHKHGNhCAgAcCCAQPUR7YR0RCWfD2BEK4xqB0FiG1PgCBUBaLXq2YOehFcrsfBML5jBkBAhAYkwACYcy4ubIakZAPd+4xpzqLUPoSM2YQ8szPbIE4OJPuz30jEK7hzCgQgMB4BBAI48XMpcWIhP2w5wRCquDXv+09+jS1BqHmqUPcYlS/uyIO6pkd3QKBcJQc20EAArMTQCDMHuGJ/EMkbAczJxDC71UQxE8tih+Lu/UUIwTCeTsV4uA8tqmeEQjX8mY0CEBgHAIIhHFihaULAURCOg1yAkG2Sr3pOPUOhCPvQdhKTmYQyndbxEE5q14tEQi9SNIPBCAwGwEEwmwRdeAPIsFBkJ25iDi4J+AIhHu4MyoEIGCfAALBfoywMEEAkUBazEIAcXBfJBEI97FnZAhAwDYBBILt+GDdDgFEAukxOgHEwb0RRCDcy5/RIQABuwQQCHZjg2UFBBAJBZBoYpIA4uD+sCAQ7o8BFkAAAjYJIBBsxgWrKgggEipg0dQEAcSBiTC8gUCwEQesgAAE7BFAINiLCRYdIIBIOACNTW4hgDi4BXtyUASCnVhgCQQgYIsAAsFWPLCmgQAioQEem15CAHFwCebiQRAIxahoCAEIOCOAQHAW8NndRSTMHuFx/UMc2IsdAsFeTLAIAhCwQQCBYCMOWNGRACKhI0y66kIAcdAFY/dOEAjdkdIhBCAwCQEEwiSBxI1XCSASyAgrBBAHViLxuh0IBLuxwTIIQOBeAgiEe/kz+okEEAknwqXrIgKIgyJMtzVCINyGnoEhAAHjBBAIxgOEeW0EEAlt/Nj6OAHEwXF2V22JQLiKNONAAAKjEUAgjBYx7K0mgEioRsYGjQQQB40AL9ocgXARaIaBAASGI4BAGC5kGHyEACLhCDW2OUIAcXCE2j3beBAI7yxof1h+1Ne9318s7d6MQvH+8v8fE9t/vBGyvfE+ORDm2vF/sYzx1Y6/ORu2xhNuHyTs32sv2wjTXx2IgXJMxUTNUF//uvxBjjv6qfUhjFncV26sXEg/T8RCObbmpoyt/W/ZHduXYvPd0ui9oOEee90+3ibHYcTvEQgjRg2bDxF4d9nqm/Vg9fXy++1DvbARBLYJIA7Gyg4EwqvCIS5GU8VdKDBSRVmu6Cst5MLib0vUHBm/RSCIHbEwGk0gpHyIY5YSf1tiZGuP38sDLa5zuRLGPSWU4u1TAi60L5fPsXCJxwzFZ26ssY6EaWs3BULJ1YY72swAHR/uIxCKhDvylzHLrmSOzun7JcUf7ktzRi4k4EEgpFA8rRdKtmYB4uI8LobCojguorauvobFXK5I7zF+jRAJGalvsY3KLL5yrO33rvQfiUGPGYRSH3Ssf1sMldmiFLtagaDFeMxFeH27/IRX7EM+Jbmp7T9c8/hf1997eaX9pmaCNIY5gaA+leRv4SHIdLPXjo9frqAtnqDl6i8fCLQSeHfpQGcSLOY5No0tIhAHrXvoddsjENKsS26jCAv+UECU3J6RK957jJ8bYyvLtgTC1tXjkQTClg9hzP5lo9iuEQja9shtODUCQQp2ifM/Lj9yW9lWzEvyKcyHVA6rXbVC8LqjWf+RvB4f+5OkRwhMSuBxPWG8nNQ/3PJLwOsJMFeE5b7XjNF24RXVPYGg3+WK9x7j58aoFQjSXq8gh4JoJIGw5UMYM10vERf3RwRC6mp97mhTGnu1WXNPt0vd+pPK0z074hzWGB/NqZzPVr/3eny0Gg/sgoA5AggEcyHBoE4EvJ4Ac0VYqhBOIU8VxyUzCLmrsD3GP1rM5WYQRr7FaOvKfhyzVEFdIxAkV7SPWpGQy81YnKog2IrbligqFQhbgqnTIch0N16Pj6aDgnEQsEQAgWApGtjSk4DXE+BeEVZze0iNQAjXLeytfeg1/tatmrnFpbk1CKl76lNPeZLx926xyRXCZ65ByK0b0bFD+2sFQliYayxy7ENhUZIjoQjcsq8mn/TYov7LrPm/Lz+1IqfnMerOvrweH+9kztgQGIoAAmGocGFsBQGvJ8ASgVByBT51y1DuyTS52YOaQvTI+Lkide+pRCkme+3vFggpkbT35KcwNroAWG/hqYlLuAum+OzFICecpG/tMxYRqW1Lb2sLbU7lcC5vKg47wzT1enwcJkAYCoG7CSAQ7o4A459FwOsJsEQglCww3ZtBSBWnJUVWzRXfvfFLBE4qr7YK/i0eltcgxDHY8iE1WxEvaD4qEOKr8rnZhBKBIG1SvqRiUZNPsa0imP7D8rP1ZKezjktW+vV6fLTCHzsgYJ4AAsF8iDDwIAGvJ8ASgVByW0V8lVnCUHJrzF64ap41vzd+q0AIF17rOKVFaUk65grhEo65F6WV+rA1lvothfI/LD97Twoq8VnaqN9b8clxyb0IL761q1UgyIsD1abc7Fcpg1HaeT0+jhIf7ITA7QQQCLeHAANOIuD1BJgrwnSR8N594GGxF7YrKWxz4ewxfk+BEPoaPwP/7BmEPT+2bp/JraOIfdiKWViM/1MngZAr2HO5mXsxne7TYU6W5pPmZcwj5JDbJ3K5PdL3Xo+PI8UIWyFwKwEEwq34GfxEAl5PgLkiTK8c7xWnW8+W7yEQeozfWyDkivHaq8u5GJQUpeEVfrnSrZ8tgbDlQ8mTp3TB7lGucfF9dAZBuW3drpYSbHszQKnDS4rH1ns/Tjw83d611+Pj7eAxAAKjEEAgjBIp7Kwl4PUEWFOcpm6r0YJL+JVeja6JTVgcHx3/aCFb8rjM8CryWTMIwivkHF+5Dr/betN16o2/qavpOVGn20i8S7huLSIO47r1NuK93CxZB7E1Q6E+7N0mlnuTcolwrclz6229Hh+txwX7IGCGAALBTCgwpDMBryfAnEAQzLmnEQm71FXzXLFZGsLW8UsK2ZQtewIh9cKs3C0vR6+Uq21hcZ5a+J0qtGt9yMUs9LGE61Em4vNebu75FcYy1UdJPuUEgoyh8dgSOKX5PUI7r8fHEWKDjRAwQQCBYCIMGHECAa8nwBKBoLi1bVic7j3hKFds1obx6PglhWytQEgtoD5aDNfEIDXGXgz2CumUDyUxU3tLuW5xyRXWe1y0OM89DWtvVqckn/Z41Cyir811a+29Hh+txQF7IGCWAALBbGgwrJEAJ8BGgGwOAQhMS4Dj47ShxTEI9CGAQOjDkV7sEeAEaC8mWAQBCNggwPHRRhywAgJmCSAQzIYGwxoJcAJsBMjmEIDAtAQ4Pk4bWhyDQB8CCIQ+HOnFHgFOgPZigkUQgIANAhwfbcQBKyBglgACwWxoMKyRACfARoBsDgEITEuA4+O0ocUxCPQhgEDow5Fe7BHgBGgvJlgEAQjYIMDx0UYcsAICZgkgEMyGBsMaCXACbATI5hCAwLQEOD5OG1ocg0AfAgiEPhzpxR4BToD2YoJFEICADQIcH23EASsgYJYAAsFsaDCskQAnwEaAbA4BCExLgOPjtKHFMQj0IYBA6MORXuwR4ARoLyZYBAEI2CDA8dFGHLACAmYJIBDMhgbDGglwAmwEyOYQgMC0BDg+ThtaHINAHwIIhD4c6cUeAU6A9mKCRRCAgA0CHB9txAErIJAk8Iflr7qT3v37JTGCwGQEOAFOFlDcgQAEuhHg+NgNJR1BoD+Bu0VBOL6IFT4QmIkAJ8CZookvEIBATwIcH3vSpC8IdCbADtoZKN1BICDA/kU6QAACEEgT4PhIZkDAMAF2UMPBwbThCbB/DR9CHIAABE4iwPHxJLB0C4EeBNhBe1CkDwhwhYwcgAAEIFBDgPqjhhZtIXAxAXbQi4EznCsC7F+uwo2zEIBABQGOjxWwaAqBqwmwg15NnPE8EWD/8hRtfIUABGoIcHysoUVbCFxMgB30YuAM54oA+5ercOMsBCBQQYDjYwUsmkLgagLsoFcTZzxPBNi/PEUbXyEAgRoCHB9raNEWAhcTYAe9GDjDuSLA/uUq3DgLAQhUEOD4WAGLphA4g8DD0unbGx3ndtDfnGEQfULACQFLLyLEFjtvjScWxIIc+DkHnJwOcBMCtgj8cjHnb8vPX5aftxKm7QmEPy3t5fvf2nIJayAwDIEv132IYoCCkBwgB8iB13Pgm2GO5hgKgckIiCgQcSAHpucVAkFEgWwj4kJEBh8IQAACEBibQG7GeGzvsB4CEIAABKoIPFuL/e8Txf7WCePrdZvfV41EYwhAAAIQsEoAgWA1MtgFAQhA4CYCf14L/j9G46dOGM/XtjL1l7ot6SYXGBYCEIAABBoIIBAa4LEpBCAAgRkJPCxOye1CcoKQf+snPmHI7UTfru2ezQgCnyAAAQg4JYBAcBp43IYABCCwR+DTtfCXhZNbAkHbyIwDHwhAAAIQmIcAAmGeWOIJBCAAgW4E3l560tmBD9dewxPGwyogZKZB/s0HAhCAAATmIYBAmCeWeAIBCECgK4HfrSJAhIKsLwhPGC/X/8ssAh8IQAACEJiLAAJhrnjiDQQgAIGuBPQJRU+BQHgWCIe3u45GZxCAAAQgYIEAAsFCFLABAhCAgFEC8nZkfceBnjDkiUXyb5lh4AMBCEAAAvMRQCDMF1M8ggAEINCVwOerIAjf7CgzC3wgAAEIQGBOAgiEOeOKVxCAAAS6EZDHmepjT/WkITMLfCAAAQhAYE4CCIQ544pXEIAABLoSeFp60xPGZ117pjMIQAACELBGAIFgLSLYAwEIQMAgAXmKkTzNSGYSZEaBDwQgAAEIzEsAgTBvbKfx7A/BlcvwHui7/81V1GlSDEcKCTxb2j0vbEszCEAAAhAYlwACYdzYubH8biGwN76bIODorQT0UaMiSj8KBPMd//+PN48f+v9/r7bcweHuOMTjP96aoQwOAQjMRgCBMFtEJ/THYpJatGnC0OPSSuAJEkkCL+DydwJyTOIDAQhAoBcB6pxeJOnnNAIWk9SiTacFgI5vJ4BASIeAovhnLrC4fTfFAAhMRYA6Z6pwzumMxSS1aNOc0ccrIUDxh0DI7Qkvcw34HgIQgEAFAeqcClg0vYeAxSS1aNM90WHUKwggEBAIuTx7zDXgewhAAAIVBKhzKmDR9B4CFpPUok33RIdRryDwdMUgA47xYkCbzzIZEXkWWfqFgE8C1Dk+4z6U1xaT1KJNQwUVY6sIIBCYQcglDAIhR4jvIQCBGgLUOTW0aHsLAYtJatGmW4LDoJcQoPhDIOQSjTUIOUJ8DwEI1BCgzqmhRdtbCFhMUos23RIcBr2EAAIBgZBLtMdcA76HAAQgUEGAOqcCFk3vIWAxSS3adE90GPUKAk9XDDLgGC8GtPkskxGRZ5GlXwj4JECd4zPuQ3ltMUkt2jRUUDG2igACgRmEXMIgEHKE+B4CEKghQJ1TQ4u2txCwmKQWbbolOAx6CQGKPwRCLtFYg5AjxPcQgEANAeqcGlq0vYWAxSS1aNMtwWHQSwggEBAIuUR7zDXgewhAAAIVBKhzKmDR9B4CFpPUok33RIdRryDwdMUgA47xYkCbzzIZEXkWWfqFgE8C1Dk+4z6U1xaT1KJNQwUVY6sI9BIIny+jau7q748jS36x/P+roN1fl3+/FbQRW+I+Pqnypl9jK0Xx+4tLPy4/d3EQolZY9IsuPUEAAncSoM65kz5jFxGwmKQWbSqCSaMhCfQq/kQgfLH8vLlS0MJWRYKKg7DNh9E2IhDC799Z/v9D9LerIPfi0mJvKJjuFAisQWiJIttCAAIxAeoccsI8AYtJatEm84HEwMMEehXCsUAQg8K/qWD4YMfSWCBIUxER3y0/7x328NiGvbgcG/0nv8UG4SUc7xQIj0edYDsIQAACCQLUOaSFeQIWk9SiTeYDiYGHCUhR3uOTEwg6G7BX6KYEggiLbwOBIOPIrER4S9MZxfOLHlA69XG3QLhbLHXCSDcQgIARAtQ5RgKBGdsELCapRZvIoXkJnCUQwivgSk/GkvyO1x6E34e3GMnf4xkEFQZ661J8K1OvSFkqihEIvaJKPxCAgAUC1DkWooANuwQsJqlFm0ijeQn0KoTDK/rS59ZtQVrQp4SCCIjUOoZwhiBVLJ9RQPfi0iNzzvCvxq6XNY1pCwEIQCBDgDqHFDFPwGKSWrTJfCAx8DCBXoVweItRakFybKAKhXA2QQSC5r/+jp+ENJtAiH1O3S51t0B4PJxdbAgBCEDgdQLUOWSFeQIWk9SiTeYDiYGHCUiB2uMTCgTpL3WL0ZZI0IXLYkt8i1G8zVUC4UUPKJ36uFsg9BKRnXDQDQQgMDgB6pzBA+jBfItJatEmD7ng1cezBILOIuwtII6fbGRJIFgqihEIXvdO/IbAnASoc+aM61ReWUxSizZNFXSceYVAr0I4nkGQQaTg11uI4nceyPeyTXyLkZUZhF5ceqTb3QKBNQg9okgfEICAEqDOIRfME7CYpBZtMh9IDDxMoFchnBII8ROGRDCEawxiMcAMws9h1Fu04jUZW0+AOpwABRs+FrShCQQgAIFSAtQ5paRodxsBi0lq0abbAsTApxOQopzP6wReAOXvBHqJSJBCAAIQEALUOeSBeQIWk9SiTeYDiYGHCSAQ0ugoin/mAovDuxcbQgACCQLUOaSFeQIWk9SiTeYDiYGHCVD8IRByycMahBwhvocABGoIUOfU0KLtLQQsJqlFm24JDoNeQgCBgEDIJdpjrgHfQwACEKggQJ1TAYum9xCwmKQWbbonOox6BYGnKwYZcIwXA9p8lsmIyLPI0i8EfBKgzvEZ96G8tpikFm0aKqgYW0UAgcAMQi5hEAg5QnwPAQjUEKDOqaFF21sIWExSizbdEhwGvYQAxR8CIZdorEHIEeJ7CECghsDsdY5ceFMf9ffWS0P1kdap7/W78PHWW4/AlnH2Xkwax0cfQx7a+XHUaGus75Z272UCri9Llf733m8U2lH6GO/PA76xzTV5uNvWYpJatKkbcDoyRwCBgEDIJeVjrgHfQwACEKggMGudExbFsUDYKpRVTGwV53HRnBIf4Vi5l41KmMICO7bzgyCOe2PlREIoLvYK/1iEhOOnUipuj0Co2PFoCoEaAnIA4PM6gRdA+TsBRCTJAAEI9CQwq0B4Z4H0w/ITF61aaKeKai3Ww8JYi+DS9hIbvRJfWrjH7WT7b5efcGYgZZv6KDHcKs5VKIkw+K/Lz55NMoZ8/38sP3t9io81/Tbnq8UktWhTM2g6MEsAgZAODUXxz1xgYXb3xTAIDEnAW52jRXVcKGvBG/59r9BPtdcE2PsuTBIt+nNX3vf6y/WhgkhET/jvOFnDgv9/WwXC3m1S2tc/LW2/Wn5Kb0k6tJNYTFKLNh2Cy0ZDEKD4QyDkEvVlrgHfQwACEKgg4K3O2Sr6VThooZubBdDvU7cR7X2XEgi5W3m2+gtvo0r1oT6pjTobkhIkYdtfLUbK7MvWLVJqjwiIUl8rUvL1phaT1KJNTZDZ2CyB36+KPXWvJH97fZGZVyb/xWwGYxgEIDAiAW91jl75jq+OhwuUc+JA4ry1oLlkW80TtSW3ViE1VsnCY+1fxcPeIuyw6A9nE95KJLXeiiS3QO312W1/sJikFm3qBpyOTBGQK8Nei178Lo/9/zCVtRgDAQiMTsBTnbNXvGsx/b8vAf1x+cmtH9D2qfNX6ROMwjUE0s/WTMLeWLmr/OH3e1f749mFUASEOR63U9tyt0k17ScWk9SiTU2Q2dgsgWerQJCFSSnFbtZwDLuEwNdrfjy/ZDQGgQAEvBDwUueExXiqENd7+f/P9VibK/K1/dYFrtysQJhfYV+p7bbG2rs1SbcJ28S3UcU2hKJIC//c9ltCouv+YzFJLdrUFTqdmSJAEWgqHGaMQTyaCQWGQGA6Ah7qnNzTfsJFwP/LEmG5/37viv7eouHcWFsJFG4XioTaxdPSf3i7UDjelt2pW4pS6xVi0ZC7FanbzmIxSS3a1A04HZkj8Jv1oPS35fcvzVmHQXcQkNkkmVWSY5EcsPlAAAIQ6Elg9jqnpGDfWsy7NQsQt4/jcfS+/NQsx9ZV/9QMgdiRe/+DxDu+fSrlT3w7Uur2pEsWKItTFpPUok09Dwz0ZY+A7vSf2jMNi24g8Hw9NsrsEh8IQAACvQnMXOeEL/Laux0nvuKeezrQ1hV6jc1RgSDbx4X/Vl+5v2/d+qR/D3mk/AmFyT8udsmjTGNh0eJnVR5bTFKLNlVBpfFwBB4Wi2UGQX5+PZz1GNyTgMwi6ezBs54d0xcEIACBlcCsdc7T4p/4VvJ8fm0bLrTV4jc1i5BqHybU1tX9XNKlbgHaGit19b7k/Qt7tw6F/od9/fPKMl6XkeOQ87f4e4tJatGmYqA0HJaAzB5I7slBho9fAuSB39jjOQSuIjBbnRNe/c8tNFbGqYI+7Cd+Qk/J7T17i5Rl+/j7rceWbo2VeuGbFux7fqeu+ssYe2+K3hJaW9t1z12LSWrRpu7g6dAcAblyLDMIkn8P5qzDoCsIkANXUGYMCEBgtjpHi+S9W2xyi4A1K7SYDmchSu7x35u1iB9tGtuZGitVvMdrK7beEB1neDzzsLfQOGQZ36J12QJlccBiklq0icOZDwL64jTuPfcR79jLP63HxM98uo/XEIBAJwLyoAO50ivFXuqzV+dIgfxy+Xm3ky1XdKNX3PcEQniFfW/BcWoWIVfg596KLAy2+ohnKkptkzG1mM+9jyBe9Lw3xt4i5NxC7a6xtliMW7SpK3Q6M0sgfHrNM7NWYtgZBB5WccDTrM6gS58Q8EUgnI2UJ+XFn606J9zu0RcyvLVGwGIxbtEma3HDnvMIPF8Lxb8sv3l52nmcrfX85zXusgaBDwQgAIFWArqeKTUjvVXnyOylfCfHIz4QuJWAxWLcok23BonBLycgB3TJQxELfOYn8GyNtzy96O353cVDCEDgAgJyLNEnov0uGi9V5zysxyGZxZR/84HArQQsFuMWbbo1SAx+OYGwYGQW4XL8lw+IILwcOQNCwAUBEQZS08QXH1J1jh6HmMV0kRr2nbRYjFu0yX4ksbA3AVkkJrn4h94d058pAh+tcf5m+Y0YNBUajIHAFARShX9c5+iTe5jFnCLkczhhsRi3aNMc0caLGgIPa+HIotUaamO1ZVH6WPHCWgiMSEAWKUtdE76IM6xzwuNQfCvSiP5i8yQELBbjFm2aJNy4UUng8/XA/sfK7Wg+BoHna3xTiwjH8AArIQCBEQjoI5TlnCKfsM6RWWr5P8ehESLpyMaWYjx+rmsvbC029bKBfiAgBHhx1rx5ILH9fj0xP87rJp5BAAIGCITnkmeBQHh3+Tcv6DQQIEx4nUBLMZ566cTea65L+bfYVDoG7SBQSkAWjElO6pWf0u1oZ5sAcbUdH6yDwGwE9EWc8ghtrXN0lvqz2ZzFn/EJ9CjGt16BHb41r4ZUD5tqxqMtBPYIyJUffVTdb0E1BQGu2k0RRpyAwFAEZK2BPAxBaxz9zTq3ocLox9jexfiWWMi9hjok3tsmP9HE07MIPF8P6lbuEX1KnGRkv0m9bj5uG8/y6dMz4pNWzT57Fvez+tWrdjKLwAcCEIDAVQSeJY7dcn7hAwFzBM4sxlNi4buFwHsZCmfaZC4AGDQEgfApE1JQ3/2Roj/el1QIhCJhq11Y/Is/cV8qGo7OAt7NZ2/8h/UEzVU7y1HCNgjMS0Df2q4Lk3m88ryxHtqzs4pxLVbiq5L6/78u1LZ2irNsGjpQGH87gfA51Xcf0FOFv64J0qI+/v8WwJRAkLZylX1vP709IAcNeLkKBN5vcRAgm0EAAk0E5CKFLkzmttUmlGx8JoGexXjqVoW4wNBZBQTCmVGl77MIyC1Gss88P2uAwn5rBELuwQFbAiEeQ/4vff1q+flh5SAs4luRStsVutq12bPVbllTcrfI6+oYnWUJ6KMkty5a8ffX742HCUzIAT858NpC+VaBsHX/cupe6OwRfG3QalPpOLSDQC0Budoj+SkFpixevuuTEghyxT++VUjvtd+7Vah0BkHGFN9Dca9/i29rKml3BzsrAu8O372PSaHjp9Ah1sSaHDiWA6+cJ1qK8fgxp70WNRLYY4GF27XcPr2x4tLCPIz51kyBigRpm2qTEgjaf7hPp0SJHgOOtLsa3/NV4IhIYPbgavr3j9dyrrvfeiyAAAQgcB6B5PGx5aAptwv9p+Xnzc42U+heW+jC+xjvOxe5xsV66kp+uFvGDwyIFynHOZB6mICMsXXLYDhDUdqu82Fjt7twkfmzKwdmLDMEWs51ZpzAEAhAAAInEDhFIHyVKBpabedA3kqQ7c8m8MdlAMlTuTp/xycWCCVre8ROveIfCoCtW4xiv0oL/9J2V3LTFxTJ7AEfnwQ4r/iMO15DAAJ5At0FQulTUvKmvdqCA3ktMdpfTUDWH+hTKB6uHnwZLxYIYoKuB8qt/4nbzS4Q7o7VDenBkAkCnFdICwhAAAJpAt0FQulVy9qAcCCvJUb7OwjoU1Fe3jB4SiCUCvZ429kFgqwVuXO254b0YEgEAjkAAQhAoJhAd4EgI7+//Py4/PR8XjoCoTimNLyRwJ33tacEgqCQW550X5TCP94vdX8N1wzMLBAeFgYy0yM/v74xVxj6fgKcV+6PARZAAAI2CXQXCKk3JW8teK0REBzIbSYQVr1O4PnyJ8nXq+9t3xIIevuQLkJOPYY4ftrYzAJBBJPER2YR+PgmwHnFd/zxHgIQ2CbQXSDEjzndexoOAoHUnJGAzCL8ZS1CRSzwsUPgYY3LnU+bskMDSxAI5AAEIACBNIHuAuEs0BzIzyJLv2cQeLYWoryd9wy6x/uUWR05lsgTjPhAgPMKOQABCEAAgUAOQOBSAhSjl+LODoZoyyJy1wCB4C7kOAwBCBQSYAahEBTNIFBL4GG9Ws3tLLXk+rcPb/v6Xf/u6XFQAgiEQQOH2RCAwOkEEAinI2YAzwRYEGsj+s9XsXb1wnEb3mPFFgEEArkBAQhAIE3gNIHwtJ6QWaRM6nkmII/R1EdqyowCn+sJ3Pno2eu9ZcQaAgiEGlq0hQAEPBE4RSCUiAMZmKcYeUo1v77K4zQl32U2gc/1BO58ed313jJiDQEEQg0t2kIAAp4IdBcIqTcpy4uY/tvyI1fy5KMvZoqfvb4HngO5p7Scy9dfLu7ILILk8G/mcs28NyH7B/PWYuDVBDivXE2c8SAAgVEIdBcI+h6EsPiPBYLAkaupXyw/bxaS4kBeCIpmJgk8XwUC98BfG54/rtyZvbmW+yijcV4ZJVLYCQEIXE3gMoEgz4N/L/Duafk3txhdHW7Gu4sA98FfT/5hFQc8Rep69qOMiEAYJVLYCQEIXE2gu0DQW4w+CTzRWQX9W+o2pJzjHMhzhPjeOgF5vKbk8TfLj95uZ93mke3jCVIjR+8a2zmvXMOZUSAAgfEIdBcIgkBOzPHswNNaHIVPNQpFRA4dB/IcIb4fgYDcYiS5/HwEYwe28XHl/P3yW9Yh8IFAigDnFfICAhCAQJrAKQJhaxGyXtGTQWvEgZjOgZwUnoHAszWX5ZY7ZhHOiyhC7Dy2M/XMeWWmaOILBCDQk8ApAqGngdoXB/IzqNLnHQT+vIqET+8Y3MGYiDAHQe7kIueVTiDpBgIQmI4AAmG6kOKQdQIPq0Bg8Wz/SIWLwT/s3z09TkYAgTBZQHEHAhDoRqBZIOgCZF1zoP8P1xps/ZunGHWLIx0NRuBPq0j4bDC7rZv7fOUqtxjxgUCOAAIhR4jvIQABrwQQCF4jj9+3EuAFXv3xv710KWs75KD2rH/39DghAQTCvUHV9Yqpi4gfJEzbay99yLuVfrX8/LAeB3IXKvVdTHphc+/dTFtPX6z1IbyIunWR9MiTHgVXuM5TfVeONRdvtzho/6UXd1NsvlvsDB95v8det4+3uTdr/YzeLBCuQsWB/CrSjHMVAVmDIHktB10+7QTg2c7QWw+cV+6NeK7gD1+4Kpbm2lsTCJJfsQ9xoR5/L37WCoS94l+L61aBEG+fEnBhNqXESijYYuESixJlINvkxro3i+cdHYEwb2zxzDiBtxf79Ip37koX3//8JLMciwfjccc8OwQQCPfGQgv++KmGT+vFk/jKsbbfu9Kf8kj7SxXj0r7HDEKpDzrWvy3j/rj8pK7G1woELcZjLsIrfkltyCfHJWwra7pkf/nX9ffekyi131RxrzHMCQT1qfaJl/dm9FyjIxDmiifeDEbgo/Vgmyt6+b5MIMgsAh8IlBJAIJSSOqfdlkDYuno8kkDY8iEUI/+yUWzXCARte+Q2nBqBIAW7iJl/XH6+2hA2kiW1twWlxJnaVSsEz8lSv702C4RQKdYWMaX3sUl4OJD7TVI8v5cA+969/Bn9PALk9nlsS3reEgiyrV5BDm8vGUkgbPkQFsS6XiIu7o8IhCO34pQKBLVZr+brdqlbf/S70iv/sUDQGNfUhyW5Rpt6As0CIXef2Z5oqEkADuT1wWULCPQgwL7XgyJ9WCRAbt8bldwMwsi3GG1d2Y8L4lRBXSMQJILhhdqa+/VLBUIsCGqF3V6WlQime7PU7+jNAuEqdBzIryLNOBB4lQD7HhkxKwFy+97I5tYgpO6pl/v2Uxce926xyRXCZ65BiH2Ix9L/h/bXCgSJYnyxtkQo5LhIvylbtuw7cruT+v9yGevf19iW2H5v5voYHYHgI854CYHDBCiiDqNjQ+MEyO17A7T3VKLUHQZ77e8WCCnRkvIhJUZ0AbDelnNEIEgkU3z2iu0SgaB9xgu8U9vG78Uqya7U05UQCCXkzm+DQDifMSNAYGgCFFFDhw/jdwiQ2/emx1bBv1XsW16DEAuELR9SAiFe0HxUIGg0Sx9JWiIQpE3Kl1QsWmYQZKblPyw/W092ujdTfY7eLBB4k7LPxMFrPwQoovzE2pun5Pa9EU/dYqRX00uL0hIPcoVw71uM9nzYGku3kUL5H5afvScFlfgsbdTvrfWeOS6hcNlaT5q6NarmiUpbazJ4glFplM9rh0A4jy09Q2AKAhRRU4QRJxIEyO170yK3BiF+Es7ZMwh7D07Zun2m1octgRAW4//USSDkrujnBELuxXS6/4S3H+laiK13TsQZF/MIOZT2cW8Wzzt6s0C4Cg0H8qtIMw4EXiXAvkdGzEqA3L43slvFda4Yr726nCuES4rS8Ar/mwG2Wh/2Ziu0L12wW/Okx1Qkc2sCclz0+601ASnBtjd7smdjGNPwFinWI9y3jyIQ7mPPyBAYggBF1BBhwsgDBMjtA9A6blLyuMzwKvJZMwjikha2khPxlevwu7hgrfUhdztT+DSiEoGwtYg4FD1b7yTYEwgl6yC2ZijUh73bxHJvUlbmJQw6piRdBQRuFQj/62JIqMT3IsOBnLyFwD0E2Pfu4c6o5xMgt89nvDfCXnGdemFW7paXo/faq41hcZ665z5VaNf6kBMIoY8lxfFRJuLznkDY8yuMaaqP1JOJYp45gSBjaDxKX7p2bzbPN3p3gZBLfkF45E15HMjnSz48GoMA+94YccLKegLkdj2znlvsFaHxk33C2mFrwWyrQNgaY2/Rba0PJTWSFt0lAmGPS66w3hMIWpznbvHZm9XR/sN4xSz3eKRyoGf+0dc+ge4CIVR98VRdvCK+5j5CDuSkMgTuIcC+dw93Rj2fALl9PmNGgAAExiRwikCIFa0oxn9efnSwmkdgKVYO5GMmGFaPT4B9b/wY4kGaALlNZkAAAhCoOD72PGjGU0xHH1vV0yaSAQIQKCfAvlfOipZjESC3x4oX1kIAAtcROG0GQVxILVRBIFwXXEaCQA8CFFE9KNKHRQLktsWoYBMEIGCBwGkCIXwaQPgKbRmQW4wshB4bIFBGgCKqjBOtxiNAbo8XMyyGAASuIdBdIMSzBvEK+KfFLx2URcrXBJlRINBCQPfXt1o6YVsIGCSAQDAYFEyCAARMEDhNIOw9XqvkBRwxHQ7kJvIFIxwS+Msq6h8d+o7LcxPgvDJ3fPEOAhA4TqC7QDhuyv6WHMjPIku/ENgn8BKBQIpMSoDzyqSBxS0IQKCZAAKhGSEdQGB8Ar9eXPjlhhs5gfCb8d3HA6cEEAhOA4/bEIBAlkB3gVDyim0dtPQtgeIFB/JsLGkAgcMEvl22lJ+USNgTCE/rvvnR4ZHZEAL3EeC8ch97RoYABGwTQCDYjg/WQeASAl+vhf6nidG2BIKIib+t2z1cYiWDQKAvAQRCX570BgEIzEOgu0DIoTmyQFn65ECeI8v3EDhOQAp83cfiYn9LIOijjP90fFi2hMCtBDiv3IqfwSEAAcMELhcIwkJvQ9p70lHMjAO54SzCtCkIfLaKBBEE4SclEB7XtjKDsLV2YQooODE1Ac4rU4cX5yAAgQYCtwgEsVeuPrIGoSFybAqBzgSk0P9+LfyfBX2nBILekvT7zjbQHQSuJIBAuJI2Y0EAAiMRQCCMFC1shcDJBJ6vAkEWLOuL0WKBoG2+CdqcbBbdQ+AUAgiEU7DSKQQgMAGBWwTC+wu4H5cf3qQ8QQbhwlQERBTo7MDT6lkoEGSWQcSDHDieTeU5zngkgEDwGHV8hgAESgh0Fwg1jzn9oMTCtQ0H8gpYNIVAA4HfrgJA1xeEAuHT9bs/N/TPphCwQoDzipVIYAcEIGCNwC0C4buFwnuVJDiQVwKjOQQaCOgTiuS3CoTngXB4aOibTSFghQDnFSuRwA4IQMAage4C4SwHOZCfRZZ+IfA6gfAdB3pLkf6WWQQ+EJiBAOeVGaKIDxCAwBkEEAhnUKVPCExA4GmdMdCDhPwWkfD2BL7hAgSEAAKBPIAABCCQJnCbQJBbF3jMKWkJAbsEZMGyzhrogeJ3ds3FMghUE0AgVCNjAwhAwAmBSwVCfEUSgeAky3BzWALPgqus8nQjPhCYiQACYaZo4gsEINCTwOkC4cOgwAhvVah5i7I4zIG8Z9jpCwLlBHSR8m/KN6ElBIYgEJ6T+PfP51lYwIIcIAdOEQj6noM4wWpmDOKzCwLBxvn2DxuCj4MJBxNyYL4c+MzGYec0K8jZ+XKWmBJTcqBvDrxyAD5SjG+9/0Bfhva0jIBAOO08d1nH7Hh9dzx4wtN6Dlx2cLlhoCPnuhvMZEgIQAAClxNonkFICYPUG5IRCJfH9pQBOaGegpVOIWCOgId93YOP5hILgyAAgSEIdBMIuZefIRCGyIeskZxQs4hoAIEpCHjY1z34OEUy4gQEIHA5gWaB8IvF5K+Wn3CaPCUWEAiXx/aUATmhnoKVTiFgjoCHfd2Dj+YSC4MgAIEhCDQLhNDL1OJkFQsIhCHyIWskJ9QsIhpAYAoCHvZ1Dz5OkYw4AQEIXE6gq0AIrU893jR3G9Ke9xzIL8+N5IDEwUYcsAICZxPwsK978PHsPKF/CEBgTgKnCYQQl8wexE/qqBULHMhtJCBxsBEHrIDA2QQ87OsefDw7T+gfAhCYk8AlAiFE93kgFmoee8qB3EYCEgcbccAKCJxNwMO+7sHHs/OE/iEAgTkJXC4QFKMsbv5Py8+bhVw5kBeCOrkZcTgZMN1DwAgBD/u6Bx+NpBNmQAACgxG4TSDUcuJAXkvsnPbE4Ryu9AoBawQ87OsefLSWV9gDAQiMQQCBMEaczFjJCdVMKDAEAqcS8LCve/Dx1CShcwhAYFoCCIRpQ3uOY5xQz+FKrxCwRsDDvu7BR2t5hT0QgMAYBBAIY8TJjJWcUM2EAkMgcCoBD/u6Bx9PTRI6hwAEpiWAQJg2tOc4xgn1HK70CgFrBDzs6x58tJZX2AMBCIxBAIEwRpzMWMkJ1UwoMAQCpxLwsK978PHUJKFzCEBgWgIIhGlDe45jnFDP4UqvELBGwMO+7sFHa3mFPRCAwBgEEAhjxMmMlZxQzYQCQyBwKgEP+7oHH09NEjqHAASmJYBAmDa05zjGCfUcrvQKAWsEPOzrHny0llfYAwEIjEEAgTBGnMxYyQnVTCgwBAKnEvCwr3vw8dQkoXMIQGBaAgiEaUN7jmOcUM/hSq8QsEbAw77uwUdreYU9EIDAGAQQCGPEyYyVnFDNhAJDIHAqAQ/7ugcfT00SOocABKYlgECYNrTnOMYJ9Ryu9AoBawQ87OsefLSWV9gDAQiMQQCBMEaczFjJCdVMKDAEAqcS8LCve/Dx1CShcwhAYFoCCIRpQ3uOY5xQz+FKrxCwRmCkff2jBd7L5ed5JcSRfKx0jeYQgAAEmgggEJrw+duYE6q/mOOxTwIj7eu/X0Kk9v5l+fdvC0M2ko+FLtEMAhCAQBcCCIQuGP10wgk1H+v3lyY/BgWLMpPfH+xs/nlim7322tU7yz9+2Bjvk4y5W7Z+vLGdjvXX5fu3gjahDfF32uwXyz++Wn70+z27Q2by7y+WnzeXnz22YTsZ82gc8hH20WK0ff3ZEpZvgv1AZhQeMqEazUcfmYeXEICABQIIBAtRGMgGTqj5YOWK2Lj43iuUv1uGey8zZK7Q3irYU4IkLMxT25UIBOkjJTAsCYQtG/PR9dNixH1dRKvMJnwfCIU/Lv/+5UbYRvTRTwbiKQQgcCcBBMKd9AccmxNqPmgqEOKr909r0RIX/Vqo61VyHUH6+bZCIMTbh8IhtiUUB/EsRShwtvrcmkH4t8VemT1JiYtYIKRIKqOtGQy1LbYr1VdtHPKR9dVi5H397SVUnwYiQQSDCIdw1kuiObKPvrIRbyEAgasJIBCuJj74eJxQ8wHcKky1QA5vNdK/lcwUbI2sQiBVNKstYcGuf9sbMxQXoYDIzSCIDf+yFl6xKLEiEFJxyEfVX4sZ9vVfL2H7cyAE5BakD4NQzuCjv8zEYwhA4AoCCIQrKE80BifUfDC3BIJsqVfutejuUazuCYRUQf+0FkxbV+nVQ20XFvolAuFXSweyJiIWIFYEQioO+aj6azHTvi6LlmXxsvr05fLv3wT/9xddPIYABCCwTwCBQIZUEZipaKhyvKJxbgYhLpy1EA9nFiqGe6NkBiGcXYhFytZYqdt5SgSCLCZOiQsrAqHHrE1NfEZtW7Kvy739j40/UrxLvrT+vFz6yP2Ea2zCf48aI+yGAAQgcBYBBMJZZCftt6RomNT1Yrdy976nbgUK1wTUCoUtgRCuJdDZgpriuEUgqE2hGOopEFKFXiy8jsShOMgOGm4V0zP+3UE4cRECEIBAFQEEQhUuGiMQ8jmw9xSjrScKSa+p7VofcyrxCgVJSZGuHqZmC0pnEKQPuddbxtdblErGlqvIsk1ukXKNQEi13YtDPsI+WpQIge8XFLmr9rnvZY2AxL3153HpY+9HnmYU+vSH4P8+IoqXEIAABMoJIBDKWdGSE2pRDmwJhNKFyPFjS3MiYe8xp/G2V80gCKh4fUVPgVDzFKO40C2NQ1GwJ240y8WAeKGyrD+Qv8lnFh8nTkNcgwAEbiKAQLgJ/KjDckLNRy51a4teTa8pTp/WAiZ3tXtvDUJsbc2i6HgGQPqqmUGQ9tqHFPT/sPyEL0pLkVSfczMINQIhXGR9JA75iM/ZYvR9XR5pKrMEf1v3I3lk8EdRqEb3cc7MwysIQMACAQSChSgMZAMn1Hywcve+595urCOUXu2vEQjSt653KH2KUdiuViCEguSfDAgE8V9FSGkc8hGfs8XI+7osfBZBoD58uvz77USYRvZxzqzDKwhAwAoBBIKVSAxiByfUfKC2BMJWcb3VY2n7WoGgV9FL1kPEMx61AkF8Ux5yL/q/Lz9742rxftYMgthTyjUf6blbjLivv7uEJHzvgdxO9LATphF9nDvr8A4CELBCAIFgJRKD2MEJNR+okvcgaAGsbeOCOLzynrvSXSsQwr5TtzypgAgXGKvXRwSCbKuzFtLn3QIhtCc3i5KP9rwtRtvXRVzq7USyePqjgtCM5mOBSzSBAAQg0IUAAqELRj+dcELNx3pPIMRvNt574lGumI6L9pL78uNt4gW84f9T/R0VCKGfPQTClt2pN0anBFbqDdP5yPpqMdK+HopaeVrR24WhGsnHQpdoBgEIQKALAQRCF4x+OuGEmo/1nkBILRLeEgm5mYMWgaDbylXXuNjeW0h9VCDIeDqWBYFQs1g7H/E5W4y0r7+75pe8HbnmM5KPNX7RFgIQgEArAQRCK0Fn23NCdRZw3HVLwMO+7sFHtwmM4xCAQBMBBEITPn8bc0L1F3M89knAw77uwUef2YvXEIBAKwEEQitBZ9tzQnUWcNx1S8DDvu7BR7cJjOMQgEATAQRCEz5/G3NC9RdzPPZJwMO+7sFHn9mL1xCAQCsBBEIrQWfbc0J1FnDcdUvAw77uwUe3CYzjEIBAEwEEQhM+fxtzQvUXczz2ScDDvu7BR5/Zi9cQgEArAQRCK0Fn23NCdRZw3HVLwMO+7sFHtwmM4xCAQBMBBEITPn8bc0L1F3M89knAw77uwUef2YvXEIBAKwEEQitBZ9tzQnUWcNx1S8DDvu7BR7cJjOMQgEATAQRCEz5/G3NC9RdzPPZJwMO+7sFHn9mL1xCAQCsBBEIrQWfbc0J1FnDcdUvAw77uwUe3CYzjEIBAEwEEQhM+fxtzQvUXczz2ScDDvu7BR5/Zi9cQgEArAQRCK0Fn23NCdRZw3HVLwMO+7sFHtwmM4xCAQBMBBEITPn8bc0L1F3M89knAw77uwUef2YvXEIBAKwEEQitBZ9tzQnUWcNx1S8DDvu7BR7cJjOMQgEATAQRCEz5/G3NC9RdzPPZJwMO+7sFHn9mL1xCAQCsBBEIrQWfbc0J1FnDcdUvAw77uwUe3CYzjEIBAEwEEQhM+fxtzQvUXczz2ScDDvu7BR5/Zi9cQgEArAQRCK0Fn23NCdRZw3HVLwMO+7sFHtwmM4xCAQBMBBEITPn8bc0L1F3M89knAw77uwUef2YvXEIBAKwEEQitBZ9tzQnUWcNx1S8DDvu7BR7cJjOMQgEATAQRCEz5/G3NC9RdzPPZJwMO+rj7y+403YAADcoAcSOXAK2dAy0ni81Rtx2vLuYFtHNzIgf45YOfo098S8qV/vsAUpuTAPDnwTXzY/XL5g8UAv2Zo//MFPWYIWM0Ni/mKTTaPI8SlPC6zH3M9zJJwUoMABCBQS4BjYy0x2kMAAhCAwDQEOAlOE0ocgQAEOhLg2NgRJl1BAAIQgMBYBDgJjhUvrIUABK4hwLHxGs6MAgEIQAACBglwEjQYFEyCAARuJ8Cx8fYQYAAEIAABCNxFgJPgXeQZFwIQsEyAY6Pl6GAbBCAAAQicSoCT4Kl46RwCEBiUAMfGQQOH2RCAAAQg0E6Ak2A7Q3qAAATmI8Cxcb6Y4hEEIAABCBQS4CRYCIpmEICAKwIcG12FG2chAAEIQCAkwEmQfIAABCDwOgGOjWQFBCAAAQi4JcBJ0G3ocRwCENghwLGR9IAABCAAAbcEOAm6DT2OQwACCARyAAIQgAAEIMA0OjkAAQhAoIQAF09KKNEGAhCAAASmJMBJcMqw4hQEINBIgGNjI0A2hwAEIACBcQlwEhw3dlgOAQicR4Bj43ls6RkCEIAABIwT4CRoPECYBwEI3EKAY+Mt2BkUAhCAAAQsEOAkaCEK2AABCFgjwLHRWkSwBwIQgAAELiPASfAy1AwEAQgMRIBj40DBwlQIQAACEOhLgJNgX570BgEIzEGAY+McccQLCEAAAhA4QICT4AFobAIBCExPgGPj9CHGQQhAAAIQ2CLASZDcgAAEIPA6AY6NZAUEIAABCLglwEnQbehxHAIQ2CHAsZH0gAAEIAABtwQ4CboNPY5DAAIIBHIAAhCAAAQgwDQ6OQABCECghAAXT0oo0QYCEIAABKYkwElwyrDiFAQg0EiAY2MjQDaHAAQgAIFxCXASHDd2WA4BCJxHgGPjeWzpGQIQgAAEjBPgJGg8QJgHAQjcQoBj4y3YGRQCEIAABCwQ4CRoIQrYAAEIWCPAsdFaRLAHAhCAAAQuI8BJ8DLUDAQBCAxEgGPjQMHCVAhAAAIQ6EuAk2BfnvQGAQjMQYBj4xxxxAsIQAACEDhAgJPgAWhsAgEITE+AY+P0IcZBCEAAAhDYIsBJkNyAAAQg8DoBjo1kBQQgAAEIuCXASdBt6HEcAhDYIcCxkfSAAAQgAAG3BDgJug09jkMAAggEcgACEIAABCDANDo5AAEIQKCEABdPSijRBgIQgAAEpiTASXDKsOIUBCDQSIBjYyNANocABCAAgXEJcBIcN3ZYDgEInEeAY+N5bOkZAhCAAASME+AkaDxAmAcBCNxCgGPjLdgZFAIQgAAELBDgJGghCtgAAQhYI8Cx0VpEsAcCEIAABC4jwEnwMtQMBAEIDESAY+NAwcJUCEAAAhDoS4CTYF+e9AYBCMxBgGPjHHHECwhAAAIQOECAk+ABaGwCAQhMT4Bj4/QhxkEIQAACENgiwEmQ3IAABCDwOgGOjWQFBCAAAQi4JcBJ0G3ocRwCENghwLGR9IAABCAAAbcEOAm6DT2OQwACCARyAAIQgAAEIMA0OjkAAQhAoIQAF09KKNEGAhCAAASmJMBJcMqw4hQEINBIgGNjI0A2hwAEIACBcQlwEhw3dlgOAQicR4Bj43ls6RkCEIAABIwT4CRoPECYBwEI3EKAY+Mt2BkUAhCAAAQsEOAkaCEK2AABCFgjwLHRWkSwBwIQgAAELiPASfAy1AwEAQgMRIBj40DBwlQIQAACEOhLgJNgX570BgEIzEGAY+McccQLCEAAAhA4QICT4AFobAIBCExPgGPj9CHGQQhAAAIQ2CLASZDcgAAEIPA6AY6NZAUEIAABCLglwEnQbehxHAIQ2CHAsZH0gAAEIAABtwQ4CboNPY5DAAIIBHIAAhCAAAQgwDQ6OQABCECghAAXT0oo0QYCEIAABKYkwElwyrDiFAQg0EiAY2MjQDaHAAQgAIFxCXASHDd2WA4BCJxHgGPjeWzpGQIQgAAEjBPgJGg8QJgHAQjcQoBj4y3YGRQCEIAABCwQ4CRoIQrYAAEIWCPAsdFaRLAHAhCAAAQuI6AnQX6/8QYMYEAOkANxDlx2MGYgCEAAAhCAgBUCXy6GUBTBgBwgB8iB13PgGzlQ//+nR7EfVMxsMAAAAABJRU5ErkJggg==)

The Top of Return Stack (TORS) value is implemented as a 32 bit hardware register and the remainder of the return stack in a dedicated, dual ported 2KB SRAM block the second port of which is mapped to the CPU address space.

* The multiplexer RSn updates TORS with either the value from the top of the parameter stack (TOS), or the program counter of the next instruction following the instruction that is currently being executed. The latter represents the operation of a JSR or BSR instruction.
* The multiplexer RSPn updates the return stack pointer with either no change (0), decrement (-1, return stack size decreases), increment (+1, return stack size increases), or load from the parameter stack (TOS). The multiplexer is driven by a signal from control unit microcode.
* There is a secondary multiplexer, RSPnn driven by an auxiliary signal from the control unit that is able to decrement the return stack pointer regardless of the state of control unit microcode and the RSPn multiplexer. This is required because logic for the RTS instructions is hardwired rather than controlled by microcode.

3.6. The Control Unit

The main components of the control unit are:

* A finite state machine (FSM) which determines next state logic and control signal outputs
* Microcode held in a 2KB SRAM block which decodes instruction opcodes into control signals that can be routed directly to the datapath
* A program counter and associated logic which step execution through memory in the appropriate order
* Memory access logic which (a) routes memory write connections between the relevant bytes of the parameter stack registers and the appropriate system memory channels, and (b) accumulates byte or word length data from successive memory read cycles into a longword register which is connected to the datapath.

### 3.6.1. The finite state machine

The FSM is responsible for setting the values of control signals according to the current state and the current program instruction. Since the majority of CPU instructions execute in a single cycle, in most cases there is no change of state from instruction to instruction. The state in which all of the single-cycle instructions are executed is documented in the VHDL source code with the name “common”. The state machine changes state from common to one of a number of other states for the following events:

* Instructions that take more than a single cycle to execute (?dup, multiply, divide, load literal, memory fetch, and memory store)
* Jumps, branches, and returns
* Interrupts and traps

The manner in which the FSM impacts the operation of the microcode, the program counter, and memory access logic is documented within the following sections.

### 3.6.2. Microcode

The CPU datapath requires 14 control lines to direct the various multiplexers and computation units appropriately for each instruction (plus one auxiliary control line for the RTS instruction). A simple “hardwired” decoder in the CPU control unit might require that some or all of these control lines to be represented directly in the bits of the CPU instruction set. However by using microcode, the 14 control lines can be obtained from only 6 bits in the CPU instruction by configuring a 2K SRAM block with 6 address lines and 14 data lines. The enables higher code density with single-byte instruction encoding to be achieved.

There is a latency of one clock cycle for reading the microcode from the SRAM. This corresponding to the second stage of the 3 stage pipeline of the CPU (that is instruction read, microcode read, and register update).

The FSM controls use of microcode as follows:

* Ordinarily the least significant 5 bits of the current instruction (opcode) are passed to the microcode as an address value to access the 2KB SRAM block.
* Upon an interrupt, an override occurs and the microcode is fed with the special opcode for an interrupt since the current instruction is being deferred in favor of the interrupt.
* Upon a BRA or BEQ instruction, a NOP override to microcode occurs (i.e. the microcode is fed with the same opcode as per the NOP instruction) to prevent the lower 5 bits, which are actually now part of the branch offset in the instruction encoding, being misinterpreted as an opcode.
* Multi-cycle instructions such as load literal, memory read, and division require that the CPU control lines be as a NOP instruction until the last cycle when the new data becomes available. At that time the microcode is fed with the required special opcodes to complete register update.

### 3.6.3. Program counter

The control unit operates a simple pipeline whereby the code of the next instruction is being read from SRAM at the same time as the current instruction is being executed. This allows for the throughput of 1 cycle per instruction, although the latency in the control unit remains two cycles (A further stage for data register update in the datapath increasing the total CPU latency to three cycles).

Update of the program counter is controlled by the FSM. At each cycle the possibilities for update of the program counter are and return stack are:

* For single cycle instructions and load literal instructions, add one to the PC. Load literal instructions proceed byte by byte through the literal data using the PC.
* For other multi cycle instructions, add zero to the PC until the last cycle of the instruction and then add one. This is required to prime the pipeline at the appropriate time so that the next-but-one instruction is read from memory just as the state machine prepares to execute the next instruction.
* For an external interrupt, redirect the program counter according to the vector number provided by the interrupt controller. In this case the current value of the program counter needs to be placed on the return stack, since the current instruction will not be executed.
* For a TRAP or RTI\_TRAP instruction, redirect the program counter to the trap vector. (The RTI\_TRAP instruction is a two-phase instruction used for single stepping; first of all an RTI from the current trap routine is made, then one instruction at the current PC is executed, and then control is passed immediately back to the TRAP vector). For a simple TRAP instruction the PC of instruction following the current instruction is stored on the return stack.
* For a jump (JSR, JMP), redirect the program counter to the value currently on the top of the parameter stack (TOS). In the case of a JSR, also save the address of the next instruction on the return stack.
* For a branch instruction (BSR, BRA, BEQ), if the branch is taken redirect the program counter to the value of the PC plus the value on the top of stack. BRA and BEQ are two byte instructions and the PC will be on the second byte when the branch calculation is made. This needs to be taken into account by the assembler when calculating branch offsets.

### 3.6.3. Memory channels

The CPU has three separate memory channels. Each of these channels has a read data bus, a write data bus and control signals as required. A single address bus is common to all channels.

* An 8-bit data channel to SRAM
* An 8-bit data channel to PSDRAM via the DMA controller
* An 16-bit data channel to PSDRAM via the DMA controller

Depending on the memory address and the instruction being executed, the FSM will determine which of these channels should be active, set the appropriate control signals, and route the address and data connection.

The following describes how the memory channel components are managed by the FSM in various situations:

* Address out bus – either the current top of stack (TOS) value (for fetch and store instructions) a or the current program counter value (for all other instructions, including load literal and instructions that do no access system memory).
* Data out bus – since all store instructions have the address value on the top of stack (TOS) and the data value as the next on stack (NOS), data out in any state will either be the high or low word of NOS, or one of the four bytes of NOS.
* Data in bus – data in is routed to a 32 bit accumulator register that is able to read either 16 or 8 bits at a time at the low-end, and concurrently shift from the low end to the higher end of the register the data read on the previous cycle. When filled the accumulator is read into the TOS register. In this way the use of datapath multiplexers is reduced and the state machine becomes more economical than would be the case if TOS were populated directly byte-by-byte or word-by-word from memory.
* Control signals – SRAM access requires only a write request (WRQ) control signal. Since both read and write operations to SRAM are guaranteed to complete in a single clock cycle the state logic can proceed from state to state without waiting for any acknowledgement signal. Access to PSDRAM through the DMA controller also requires a read request (REQ) signal and the FSM must wait and monitor the ready (RDY) signal from the DMA controller before advancing to the next state in the memory access process.

# 4. Other hardware components

## 4.1. Interrupt controller

The interrupt controller is a scheduler for managing CPU interrupts. Interrupt requests (IRQ’s) are made via edge-triggered signal lines from the interrupt generating hardware units. An interrupt mask applied by the interrupt controller determines which signal lines are considered active at any one time. This interrupt mask is readable and writable by the CPU as a memory mapped hardware register. Post masking, each interrupt signal line is assigned a priority number (1 – n), with the lower numbers having the higher priority.

Interrupts on the N.I.G.E. Machine are blocking. Once an interrupt is in progress no further interrupts may occur until the original interrupt completes, regardless of their relative priority. In the default configuration of the N.I.G.E. Machine there are six hardware interrupt signal lines connected to the interrupt controller.

|  |  |  |
| --- | --- | --- |
| **Interrupt number** | **CPU vector address** | **Hardware connection** |
| 1 | 0x04 | Read Data Available (RDA) of the RS232 port 1 |
| 2 | 0x06 | Read Data Available (RDA) of the RS232 port 0 |
| 3 | 0x08 | Transfer Bus Enable (TBE) of the RS232 port 1 |
| 4 | 0x0A | Transfer Bus Enable (TBE) of the RS232 port 0 |
| 5 | 0x0C | PS/2 data available (input) |
| 6 | 0x0E | System generated millisecond interrupt |

RDA signals from the two RS232 ports are given highest priority since these signals indicate that new data is available and must be read before being overwritten. RS232 port 1 is given top priority since it is intended to connect to an SD-card reader/writer and will generally operate at a higher baud rate than port 0, which is intended as a general purpose terminal. TBE signals from the RS232 ports on interrupts 3 and 4 indicate that current byte transmission is now finished and that the transfer bus should be reloaded. The PS/2 interrupt number 5 indicates a key code has been received from the keyboard. A system generated timer driven interrupt operates at 1 kHz on interrupt 6, but this is masked off at power-on as the FORTH environment does not use it.

The memory mapped register used to operate the video controller are as follows:

|  |  |  |  |
| --- | --- | --- | --- |
| **Register** | **Address** | **Width (bytes)** | **Description** |
| IRQ\_MASK | 0xF81C | 2 | Mask applied to all interrupt signal lines by the interrupt controller. ‘1’ indicates interrupt active. Bit 0 is unused. |

The interrupt controller can easily be extended to accept interrupts from custom hardware units. As currently configured there are 15 available interrupt lines of which 6 are already assigned as described above. The VHDL file for the interrupt decoder includes comments indicating how this would be done, but essentially all that is required is for a new interrupt signal like to be routed to the interrupt controller and for some small extensions to be made to the finite state machine to accommodate it.

The following is a more detailed description of the interrupt controller process:

1. Signal lines from interrupt generating hardware units are masked with the interrupt mask. (There are no non-makeable interrupts.)
2. An interrupt request (IRQ) is generated when a masked signal line transitions from low to high.
3. When the CPU is not currently executing an interrupt subroutine, the lowest numbered interrupt requested at a particular cycle is actioned. Unsuccessful IRQ’s occurring during that same cycle are carried forward indefinitely until they can be satisfied.
4. When the CPU is currently executing an interrupt, no further interrupts are actioned regardless of their priority. All IRQ’s received at this time are carried forward indefinitely until they can be satisfied.
5. Execution of an RTI instruction by the CPU signals to the interrupt controller that the CPU has completed the current interrupt subroutine and is now free to accept another interrupt.
6. Unsatisfied IRQ’s occurring multiple times with same interrupt number are not counted. Only a single IRQ of that interrupt number is carried forward.

## 4.2. Reset Controller

The reset controller provides a reset signal to the CPU, DMA controller and video adapter. A short reset signal is given to all three sub-systems at power on. In addition, a two-second reset signal is triggered when the Digilent IO interface writes to memory address 0x00 as part of a firmware update. This allows time for the firmware update to complete before the CPU resumes execution.

## 4.3. Direct Memory Access (DMA) Controller

The DMA controller provides shared access for the CPU, the graphics adapter, and other components to the 16MB of PSDRAM (Pseudo Static DRAM) provided on the Nexys2 board.

The available DMA channels and their characteristics are scheduled below:

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Channel** | **Address width** | **Data width** | **Direction** | **Pri-or-ity** | **Notes** |
| PSDRAM | 23 | 16 | Bi | n/a | External connection from the FPGA to the 16MB PSDRAM. The PSDRAM is byte or word addressable using a 23 bit address bus (i.e. address bits 24 downto 1) with separate lines for enabling hi and lo byte access |
| CPU-16 | 23 | 16 | Bi | 3 | 16 bit wide read/write used by the CPU operations that read or write word and longword data |
| CPU-8 | 24 | 8 | Bi | 4 | 8 bit wide read/write used by the CPU operations that read or write byte data |
| GFX | 9 | 8 | Read only | 2 | Feeds pixel graphics data to the video controller from a 512 byte SRAM buffer |
| TXT | 7 | 16 | Read only | 1 | Feeds character/text graphics data to the video controller from a 256 word SRAM buffer |
| Others | 8/16 | 8/16 | Bi | \* | Other channels are available for expansion. For example for use by logic units such as a blitter or hardware line drawer |

The available PSDRAM operating in random access mode does not have sufficient throughput speed to support the requirements of the video controller with a 25MHz pixel clock. Instead the DMA controller includes two fast on-board SRAM (static RAM) buffers for feeding character and pixel data to the graphics controller in synchrony with the VGA pixel clocks. The buffer maintenance logic of the DMA controller leverages the burst mode capabilities of the PSDRAM to fill the buffers with sequential data from PSDRAM at a much higher rate than would be possible with random access.

Highest DMA priority is given to the character and pixel graphics buffer maintenance logic so that the buffers can be filled before the pixel clock begins each relevant scan line.

The base address of both the pixel and character graphics frame buffers in PSDRAM are set by memory mapped registers that can be read and written by the CPU (see the section on System Hardware Registers below), thus enabling video features such as flexible double buffering.

## 4.4. Video controller

The video controller drives a standard VGA interface socket on the Nexys2 board and provides both character/text and pixel graphics with the following specifications:

|  |  |  |  |
| --- | --- | --- | --- |
| **Display** | **Resolution** | **Color depth** | **Aspect ratio** |
| Character/text graphics | 80\*60 characters, each 8\*8 pixels | 8 bits | 1:1 |
| Pixel graphics | 640\*480 pixels | 8 bits | 1:1 |

Character graphics are stored in the PSRAM frame buffer as 80\*60 consecutive 16 bit words. Each word represents a single on-screen character position. The high byte (lower memory address) is the color data and the low byte (higher memory address) is the character selection.

There are two modes of color data interpretation. In mode 0, the highest 4 bits of the color byte (i.e. bits 23 down to 16 of the word = bits 7 down to 4 of the high byte) are interpreted as the background color for that character position, and the lowest 4 bits as the foreground color. Mode 0 therefore provides 16 foreground and 16 background colors for each character position. In mode 1, all 8 color bits are interpreted as the foreground color, and a common background color for the whole screen is set via a separate CPU addressable hardware register. Mode 1 therefore provides 256 colors for each character position and a single screen background color. Mode selection is made by another hardware register.

Character definitions are held in a dedicated 2KB SRAM block. Each character is 8\*8 pixels with a 1:1 aspect ratio. There are 256 characters which include the ASCII set, the Greek alphabet, graphics characters, some Japanese kana, and some scientific symbols. The character definitions SRAM block is memory mapped and can be read and written to by the CPU, thus allowing user-defined character-definitions.

The frame buffer allocated to the character/text display is 19,200 bytes in size which corresponds to 120 lines of characters/text (i.e. twice the number of lines as there are on screen). The FORTH environment uses a technique for text display where scrolling is achieved by moving the base address of the character/text frame buffer forward by 160 bytes (80 characters, one line) until the end of the buffer is reached. This is a much faster system that also considerably reduces the amount of memory coping needed when screen scrolling compared with a static frame buffer the same size as the display area.

Pixel graphic data is stored in PSRAM as 640\*480 consecutive bytes (i.e. “chunky” format). Each byte is interpreted as the color of a single on-screen pixel, with 256 colors available.

The character/text and pixel graphics displays may be independently switched on and off via a hardware register. When both are active, output pixels are combined with XOR. When either one is inactive, DMA to the PSRAM is switched off for that channel thus saving memory bandwidth for the CPU.

The power-on configuration of the N.I.G.E. Machine is character/text graphics on in mode 1 and pixel graphics off.

Memory mapped registers used to operate the video controller are as follows:

|  |  |  |  |
| --- | --- | --- | --- |
| **Register** | **Address** | **Width (bytes)** | **Description** |
| CHAR\_ZERO | 0xF800 | 4 | Pointer to the character/text graphics frame buffer in PSDRAM. The default location is 0x10700, with 19,200 bytes reserved. The character graphics frame buffer must lie within PSRAM, i.e. at or above address 0x10000 |
| GFX\_ZERO | 0xF804 | 4 | Pointer to the pixel graphics frame buffer in PSDRAM. The default location is 0x015200, with 307,200 bytes reserved. The pixel graphics frame buffer must lie within PSRAM, i.e. at or above address 0x10000 and on a 256 byte boundary. |
| BACKGROUND | 0xF808 | 1 | Background color displayed in character/text mode 1 |
| VIDEO\_MODE | 0xF809 | 1 | Bit 0 – Character/text graphics off or on (0/1)  Bit 1 – Character/text graphics mode 0 or 1 (0/1)  Bit 2 – Pixel graphics off or on (0/1)  Bit 3-7 - Unused |

## 4.5. RS232 controllers

There are two RS232 controllers in the default configuration of the N.I.G.E. Machine. Port 0 drives a standard DB9 RS232 interface socket on the Nexys 2 board. Port 1 is routed to a PMOD expansion port where it can be connected to an external SD-card reader/writer.

The configuration of the RS232 interface fixed as below:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Data bits** | **Stop bits** | **Parity bits** | **Baud rate** | **Handshaking** |
| 8 | 1 | 0 | Software selectable | none |

The controllers are operated by the use of memory mapped registers and interrupts as follows:

|  |  |  |  |
| --- | --- | --- | --- |
| **Register** | **Address (HEX)** | **Width (bytes)** | **Description** |
| RS232\_0\_DATAIN | 0xF80A | 1 | This register is updated with latest byte received from port 0 each time RDA (see below) goes high |
| RS232\_0\_DATAOUT | 0xF80B | 1 | Writing to this register will trigger output of the byte to port 0, provided that TBE (see below) is high |
| RS232\_0\_UBRR | 0xF80C | 2 | Baud rate selector, set according to the following UBRR = CPU / (baud+1) / 16  The default value is 325, corresponding to 9600 baud with a 50MHz clock frequency. Port 0 register. |
| RS232\_1\_DATAIN | 0xF80E | 1 | Port 1 read data. |
| RS232\_1\_DATAOUT | 0xF80F | 1 | Port 1 write data |
| RS232\_1\_UBRR | 0xF810 | 2 | Port 1 UBRR |
| RS232\_SIGNAL | 0xF812 | 1 | Bit 0 – RDA (Read Data Available) on port 1, goes high for one cycle when a byte is received.  Bit 1 – RDA (Read Data Available) on port 0  Bit 2 – TBE (Transfer Bus Enable) on port 1, is held high when the output bus is available and held low when the bus is busy  Bit 3 – TBE (Transfer Bus Enable) on port 0  Bits 4 – 7 – Unused |

|  |  |  |  |
| --- | --- | --- | --- |
| **Interrupt** | **Priority** | **Vector (HEX)** | **System interrupt handler** |
| RDA\_1\_EVENT | 1 | 0x04 | Triggered by the RS232 RDA signal, the interrupt handler copies the received byte to a 256 byte RS232 input circular buffer. The RS232 input buffer is tested and read with the FORTH words SKEY? and SKEY. The buffer is overwrite protected; once the buffer is full newly received bytes are discarded until sufficient calls to SKEY free space in the buffer. Port 1 |
| RDA\_0\_EVENT | 2 | 0x06 | RDA on port 0 |
| TBE\_1\_EVENT | 3 | 0x08 | Triggered by the RS232 TBE signal, the interrupt handler will consecutively output the bytes held in the RS232 output buffer. The location and size of the RS232 output buffer are set for each write by the FORTH word STYPE, which thus provides asynchronous RS232 output. Port 1 |
| TBE\_0\_EVENT | 4 | 0x0A | TBE on port 1 |

## 4.5. PS/2 controller

The PS/2 controller connects a PS/2 keyboard interface socket on the Nexys2 board. Memory mapped registers and interrupts used to operate the controller are as follows:

|  |  |  |  |
| --- | --- | --- | --- |
| **Register** | **Address (HEX)** | **Width (bytes)** | **Description** |
| PS2\_DATAIN | 0xF813 | 1 | This register is updated with latest byte received from the port. |

|  |  |  |  |
| --- | --- | --- | --- |
| **Interrupt** | **Priority** | **Vector (HEX)** | **System interrupt handler** |
| PS2\_EVENT | 5 | 0x0C | Triggered by an interrupt from the PS/2 controller |

The FORTH environment includes an interrupt handler and a decoder for translating raw PS/2 keystrokes into ASCII values.

## 4.7. System hardware registers

The system hardware registers are a set of registers implemented with FPGA logic elements used for I/O interface and communication with the various peripheral controllers. The registers have been memory mapped to the CPU address space adjacent to the top of the SRAM address space. The system memory map later in this manual contains full details.

## 4.8. Digilent I/O port

The Nexys 2 board incorporates a USB port for connection to a PC running the Digilent programming software package, Adept. Adept allows configuration of the FPGA and also facilitates general data transfer from the PC to the Nexys 2 board. As an aid to debugging, a Digilent I/O port has been incorporated into the N.I.G.E. machine to allow re-flashing of the system software in SRAM without needing to resynthesize the entire design.

## 4.9. PSDRAM

The Nexys 2 board incorporates 16 MB of Pseudo Static Dynamic RAM (PSDRAM) which is accessible via the DMA controller. The N.I.G.E. Machine CPU cannot execute code residing in PSDRAM, but may freely access PSDRAM for data storage. The frame buffers for character/text and pixel graphics are held in PSDRAM along with some FORTH language buffers.

## 4.10. SRAM

The Xilinx XC3S1200E FPGA includes 56KB of 2KB each dual ported SRAM blocks. These are utilized in the N.I.G.E. Machine as follows:

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| **Component** | **RAM** | **CPU address** | **Port A** | **Port B** | **Comments** |
| System RAM | 44KB | 0x0000 | CPU address space | Digilent I/O port | System RAM holds the executable code and is pre-loaded with the system software (FORTH environment) at power on |
| Parameter stack | 2KB | 0xE000 | CPU address space | CPU datapath | To facilitate a throughput of one cycle per instruction for most instructions dedicated SRAM blocks are used for both the parameter and return stacks. These are accessed directly by the CPU datapath as if they were a register file, but are also available in the CPU address space |
| Return stack | 2KB | 0xE800 | CPU address space | CPU datapath |
| Character RAM | 2KB | 0xF000 | CPU address space | Video controller | Character RAM is pre-configured with the N.I.G.E. machine 256 character 8x8 pixel character set. It can be accessed by the CPU for reprogramming as desired |
| Microcode | 2KB | n/a | CPU control unit | n/a | The CPU control unit microcode is organized as 14 bits of data available over 64 addresses (6 bits) for decoding CPU instructions |
| DMA buffers | 4KB | n/a | DMA controller | Video controller | Two 2KB buffers are filled by the DMA controller with data from the text and graphics buffers in PSDRAM via burst mode. The video controller reads display data from these buffers at the pixel clock rate of 25MHz. |

# 5. CPU instruction set reference

|  |  |  |  |
| --- | --- | --- | --- |
| **Assembler mnemonic** | **Instruction length (bytes)** | **Encoding** | **Duration (cycles)** |
| **Description** | | **Parameter stack effect** ( before -- after)  ( 3rd 2nd 1st on stack --) | **Return stack effect** |

|  |  |  |  |
| --- | --- | --- | --- |
| **NOP** | 1 byte | 0x00 | 1 cycle |
| No operation | | ( --) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **DROP** | 1 byte | 0x01 | 1 cycle |
| Remove top item from parameter stack | | ( x --) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **DUP** | 1 byte | 0x02 | 1 cycle |
| Duplicate the top stack item | | ( x -- x x) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **?DUP** | 1 byte | 0x03 | 2 cycles |
| Duplicate the top stack item only if non zero | | (x -- x x | x) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **SWAP** | 1 byte | 0x04 | 1 cycle |
| Exchange the two top stack items | | ( x y -- y x) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **OVER** | 1 byte | 0x05 | 1 cycle |
| Make a copy of the second item on the stack | | ( x y -- x y x) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **NIP** | 1 byte | 0x06 | 1 cycle |
| Dispose of the second item on the stack | | ( x y -- y) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **ROT** | 1 byte | 0x07 | 1 cycle |
| Rotate the top three stack times so that the second item becomes top | | (x y z -- z x y) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **>R** | 1 byte | 0x08 | 1 cycle |
| Remove the top item from the parameter stack and place it on the return stack | | ( x --) | ( -- x) |

|  |  |  |  |
| --- | --- | --- | --- |
| **R@** | 1 byte | 0x09 | 1 cycle |
| Copy the top item from the return stack to the parameter stack | | ( -- x) | ( x -- x) |

|  |  |  |  |
| --- | --- | --- | --- |
| **R>** | 1 byte | 0x0A | 1 cycle |
| Remove the top item from the return stack and place it on the parameter stack | | ( -- x) | ( x --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **LOADPSP** | 1 byte | 0x0B | 1 cycle |
| Load the parameter stack with the current value of the parameter stack pointer. The stack pointer is the count of items currently on the stack and also directs the CPU datapath to the first stack item held in SRAM | | ( -- PSP) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **LOADRSP** | 1 byte | 0x0C | 1 cycle |
| Load the parameter stack with the current value of the return stack pointer. The stack pointer is the count of items currently on the stack and also directs the CPU datapath to the first stack item held in SRAM | | ( -- RSP) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **SAVEPSP** | 1 byte | 0x0D | 1 cycle |
| Save the top item from the stack as the current parameter stack pointer | | ( PSP --) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **SAVERSP** | 1 byte | 0x0E | 1 cycle |
| Save the top item from the stack as the current return stack pointer | | ( --) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **+** | 1 byte | 0x0F | 1 cycle |
| Add two 32 bit integer numbers. x3 = x1 + x2 | | ( x1 x2 -- x3) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **-** | 1 byte | 0x10 | 1 cycle |
| Subtract two 32 bit integer numbers.   x3 = x1 - x2 | | ( x1 x2 -- x3) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **NEGATE** | 1 byte | 0x11 | 1 cycle |
| Negate a 32 bit integer in two’s complement format | | (x1 -- x2) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **1+** | 1 byte | 0x12 | 1 cycle |
| Add 1 | | ( x1 -- x2) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **1-** | 1 byte | 0x13 | 1 cycle |
| Subtract 1 | | ( x1 -- x2) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **2\*** | 1 byte | 0x14 | 1 cycle |
| Arithmetic shift left | | ( x1 -- x2) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **2/** | 1 byte | 0x15 | 1 cycle |
| Arithmetic shift right | | ( x1 -- x2) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **MULTS** | 1 byte | 0x16 | 5 cycles |
| Multiply two signed 32 bit integers to produce a 64-bit integer that is held in the top two stack positions, highest part top of stack | | ( x1 x2 -- d3) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **MULTU** | 1 byte | 0x17 | 1 cycle |
| Multiply two unsigned 32 bit integers to produce a 64-bit integer that is held in the top two stack positions, highest part top of stack | | ( u1 u2 -- ud3) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **ADDX** | 1 byte | 0x18 | 1 cycle |
| Add two integers with extend flag as carry. The extend flag resides within the datapath and is not otherwise accessible to software. The flag is only affected by arithmetic instructions. | | ( x1 x2 -- x3) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **SUBX** | 1 byte | 0x19 | 1 cycle |
| Subtraction with extend flag as borrow. The extend flag resides within the datapath and is not otherwise accessible to software. The flag is only affected by arithmetic instructions. | | ( x1 x2 -- x3) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **DIVS** | 1 byte | 0x1A | 42 cycles |
| Divide two 32-bit signed numbers to produce a 32-bit quotient (top of stack) and a 32-bit remainder (next on stack) | | (x1 x2 -- u-rem u-quot) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **DIVU** | 1 byte | 0x1B | 41 cycles |
| Divide two 32-bit unsigned numbers to produce a 32-bit quotient (top of stack) and a 32-bit remainder (next on stack) | | (x1 x2 -- rem quot) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **=** | 1 byte | 0x1C | 1 cycle |
| Returns -1 (true) if x1 = x2 | | ( x1 x2 -- flag) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **<>** | 1 byte | 0x1D | 1 cycle |
| Returns -1 (true) if x1 <> x2 | | ( x1 x2 -- flag) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **<** | 1 byte | 0x1E | 1 cycle |
| Returns -1 (true) if x1 < x2 | | ( x1 x2 -- flag) | ( --) |
| **>** | 1 byte | 0x1F | 1 cycle |
| Returns -1 (true) if x1 > x2 | | ( x1 x2 -- flag) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **U<** | 1 byte | 0x20 | 1 cycle |
| Returns -1 (true) if u1 < u2, where u is unsigned | | ( u1 u2 -- flag) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **U>** | 1 byte | 0x21 | 1 cycle |
| Returns -1 (true) if u1 > u2, where u is unsigned | | ( u1 u2 -- flag) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **0=** | 1 byte | 0x22 | 1 cycle |
| Returns -1 (true) if x1 = 0. Equivalent to Boolean NOT | | ( x1 -- flag) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **0<>** | 1 byte | 0x23 | 1 cycle |
| Returns -1 (true) if x1 <> 0 | | ( x1 -- flag) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **0<** | 1 byte | 0x24 | 1 cycle |
| Returns -1 (true) if x1 < 0 | | ( x1 -- flag) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **0>** | 1 byte | 0x25 | 1 cycle |
| Returns -1 (true) if x1 > 0 | | ( x1 -- flag) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **FALSE** | 1 byte | 0x26 | 1 cycle |
| Place zero (false) on the stack. Equivalent to ZERO | | ( -- 0) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **AND** | 1 byte | 0x27 | 1 cycle |
| Bitwise AND | | ( x1 x2 -- x3) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **OR** | 1 byte | 0x28 | 1 cycle |
| Bitwise OR | | ( x1 x2 -- x3) | ( --) |
| **INVERT** | 1 byte | 0x29 | 1 cycle |
| Bitwise NOT | | ( x1 -- x2) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **XOR** | 1 byte | 0x2A | 1 cycle |
| Bitwise XOR | | ( x1 x2 -- x3) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **LSL** | 1 byte | 0x2B | 1 cycle |
| Logical shift left | | ( x1 -- x2) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **LSR** | 1 byte | 0x2C | 1 cycle |
| Logical shift right | | ( x1 -- x2) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **XBYTE** | 1 byte | 0x2D | 1 cycle |
| Sign extend a byte to 32 bits | | ( x1 -- x2) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **XWORD** | 1 byte | 0x2E | 1 cycle |
| Sign extend a word to 32 bits | | ( x1 -- x2) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **FETCH.L** | 1 byte | 0x2F | 5 cycles in SRAM |
| Fetch a longword from memory, big endian | | ( addr -- n) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **STORE.L** | 1 byte | 0x30 | 5 cycles in SRAM |
| Store a longword in memory, big endian | | ( n addr --) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **FETCH.W** | 1 byte | 0x31 | 3 cycles in SRAM |
| Fetch a word from memory, big endian | | ( addr -- n) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **STORE.W** | 1 byte | 0x32 | 3 cycles in SRAM |
| Store a word in memory, big endian | | ( n addr --) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **FETCH.B** | 1 byte | 0x33 | 2 cycles in SRAM |
| Fetch a byte from memory | | ( addr -- n) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **STORE.B** | 1 byte | 0x34 | 2 cycles in SRAM |
| Store a byte in memory | | ( n addr --) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **LOAD.B** or **#.B** | 2 bytes | 0x35, x1 | 2 cycles |
| Fetch inline byte to stack and zero extend | | ( -- x) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **LOAD.W** or **#.W** | 3 bytes | 0x36, x2, x1 | 3 cycles |
| Fetch inline word to stack and zero extend. High byte first | | ( -- x) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **LOAD.L** or **#.L** | 5 bytes | 0x37, x4, x3, x2, x1 | 5 cycles |
| Fetch inline longword to stack. Highest byte first | | ( -- x) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **JMP** | 1 byte | 0x38 | 2 cycles |
| Redirect program execution to the address on the parameter stack | | ( addr --) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **BSR** | 1 byte | 0x39 | 2 cycles |
| Redirect program execution by the address offset on the parameter stack and place the original next following instruction address on the return stack | | ( offset --) | ( -- addr) |

|  |  |  |  |
| --- | --- | --- | --- |
| **JSR** | 1 byte | 0x3A | 2 cycles |
| Redirect program execution to the address on the parameter stack and place the original next following instruction address on the return stack | | ( addr --) | ( -- addr) |

|  |  |  |  |
| --- | --- | --- | --- |
| **TRAP** | 1 byte | 0x3B | 2 cycles |
| Jump to the trap vector (address 0x02) and place the original next following instruction address on the return stack. Used for breakpoint debugging. | | ( --) | ( -- addr) |

|  |  |  |  |
| --- | --- | --- | --- |
| **RTS\_TRAP** | 1 byte | 0x3C | 2 cycles |
| Return from subroutine, execute one program instruction and trap again. Used for single step debugging | | ( --) | ( addr --)  ( -- addr) |

|  |  |  |  |
| --- | --- | --- | --- |
| **RTI** | 1 byte | 0x3D | 2 cycles |
| Return from an interrupt routine. Similar to RTS but also changes the interrupt controller state to unblocks further interrupts | | ( --) | (addr --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **RTS** | 1 byte | 0x40 | 2 cycles |
| Return from a subroutine that was entered via a JSR or BSR instruction | | ( --) | ( addr --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **,RTS** | 1 byte | (0x40 OR opcode) | 1 cycle |
| As RTS but is a compound for any single-cycle instruction that does not itself reference or impact the return stack. The compound instruction saves one cycle and one byte on each subroutine return (e.g. DROP,RTS). | | ( --) | ( addr --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **BEQ** | 2 bytes | (0x80 OR hi), lo | 3 cycles |
| Branch if the top of stack item is zero. The top 6 bits of the branch offset are in the first instruction byte, the bottom 8 bits of the branch address follow in a second instruction byte. The branch offset is calculated from the address of the second byte | | ( flag --) | ( --) |

|  |  |  |  |
| --- | --- | --- | --- |
| **BRA** | 2 bytes | (0xC0 OR hi), lo | 3 cycles |
| Branch. The top 6 bits of the branch offset are in the first instruction byte, the bottom 8 bits of the branch address follow in a second instruction byte. The branch offset is calculated from the address of the second byte | | ( --) | ( --) |

# 6. System software

The N.I.G.E. Machine includes a FORTH environment that is available at power on. FORTH has been described as “a language for direct communication between human beings and machines”. It combines an interactive shell with a compiler. Commands, known as FORTH words, can be issued directly at the keyboard for immediate execution or compiled into the definition of new words. FORTH is also a stack based language. Functions are implemented as words that accept numeric parameters from the top of the stack and leave return values on the stack.

## 6.1 FORTH implementation

The N.I.G.E. Machine’s FORTH environment is coded in assembly language and occupies just less than 8K of system memory. There is a one-to-one correspondence between the most primitive FORTH words and the CPU instruction set. Other FORTH words are implemented as machine language subroutines or as inline code (there is no inner interpreter). The operating model on the N.I.G.E. Machine is therefore native and subroutine threaded.

## 6.2 Cross assembler

Because the CPU instruction set is in general a subset of primitive FORTH words, the FORTH environment serves as the “local assembler” for the N.I.G.E. Machine. However the N.I.G.E. Machine’s FORTH implementation was developed on a PC with a specially developed two-pass cross assembler and the cross assembler itself is written in standard ANSI FORTH.

## 6.1 FORTH word set reference

The following reference is organized according to the categories of the ANSI FORTH documentation. Status indicates whether the word has been implemented on the N.I.G.E. Machine. Y indicates yes, N no, and that Y\* that the word is implemented by with some limitation or difference as compared with ANSI FORTH.

### 6.3.1 CORE words

|  |  |  |
| --- | --- | --- |
| **Word** | **Status** | **Notes** |
| ! | Y | See also W! |
| # | N | Use U# instead. Division with a 64-bit dividend is not implemented on the N.I.G.E. Machine. |
| #> | N | Use U#> instead. See #. |
| #S | N | Use U#S instead. See #. |
| ‘ | Y |  |
| ( | Y |  |
| \* | Y |  |
| \*/ | Y\* | The intermediate value is single (32-bit) precision only |
| \*/MOD | Y\* | The intermediate value is single (32-bit) precision only |
| + | Y |  |
| +! | Y |  |
| +LOOP | Y |  |
| , | Y | See also W, M, and $, |
| - | Y |  |
| . | Y |  |
| .” | Y |  |
| / | Y |  |
| /MOD | Y |  |
| 0< | Y |  |
| 0= | Y |  |
| 1+ | Y |  |
| 1- | Y |  |
| 2! | N | Less suitable for a big-endian processor |
| 2\* | Y |  |
| 2/ | Y |  |
| 2@ | N | Less suitable for a big-endian processor |
| 2DROP | Y |  |
| 2DUP | Y |  |
| 2OVER | Y |  |
| 2SWAP | Y |  |
| : | Y |  |
| ; | Y |  |
| < | Y |  |
| <# | Y |  |
| = | Y |  |
| > | Y |  |
| >BODY | N | Would be a no operation in the N.I.G.E. Machine FORTH environment. Will not be implemented for space and efficiency reasons |
| >IN | Y |  |
| >NUMBER | Y |  |
| >R | Y |  |
| ?DUP | Y |  |
| @ | Y |  |
| ABORT | Y |  |
| ABORT” | N | Will not be implemented for space and efficiency reasons |
| ABS | Y |  |
| ACCEPT | Y |  |
| ALIGN | N | Would be a no operation in the N.I.G.E. Machine FORTH environment. Will not be implemented for space and efficiency reasons |
| ALIGNED | N | Would be a no operation in the N.I.G.E. Machine FORTH environment. Will not be implemented for space and efficiency reasons |
| ALLOT | Y |  |
| AND | Y |  |
| BASE | Y |  |
| BEGIN | Y |  |
| BL | Y |  |
| C! | Y | See also W! |
| C, | Y | See also W, |
| C@ | Y | See also W@ |
| CELL+ | Y |  |
| CELLS | Y |  |
| CHARS | N | Would be a no operation in the N.I.G.E. Machine FORTH environment. Will not be implemented for space and efficiency reasons |
| CONSTANT | Y |  |
| COUNT | Y |  |
| CR | Y |  |
| CREATE | Y |  |
| DECIMAL | Y |  |
| DEPTH | Y |  |
| DO | Y |  |
| DOES> | Y |  |
| DROP | Y |  |
| DUP | Y |  |
| ELSE | Y |  |
| EMIT | Y |  |
| ENVIRONMENT? | N | Will not be implemented for space and efficiency reasons |
| EVALUATE | Y |  |
| EXECUTE | Y |  |
| EXIT | Y |  |
| FILL | Y | See FILL.W |
| FIND | Y |  |
| FM/M | N | Will not be implemented for space and efficiency reasons |
| HERE | Y |  |
| HOLD | Y |  |
| I | Y |  |
| IF | Y |  |
| IMMEDIATE | Y |  |
| INVERT | Y |  |
| J | Y |  |
| KEY | Y |  |
| LEAVE | Y |  |
| LOOP | Y |  |
| LSHIFT | Y |  |
| M\* | Y |  |
| MAX | Y |  |
| MIN | Y |  |
| MOD | Y |  |
| MOVE | Y |  |
| NEGATE | Y |  |
| OR | Y |  |
| OVER | Y |  |
| POSTPONE | Y |  |
| QUIT | Y |  |
| R> | Y |  |
| R@ | Y |  |
| RECURSE | Y |  |
| REPEAT | Y |  |
| ROT | Y |  |
| RSHIFT | Y |  |
| S” | Y | See also C” and ,” |
| S>D | N | Equivalent to FALSE on the N.I.G.E. Machine. Will not be implemented for space and efficiency reasons. |
| SIGN | Y |  |
| SM/REM | N | Division with a 64-bit dividend is not supported |
| SOURCE | Y |  |
| SPACE | Y |  |
| SPACES | Y |  |
| STATE | Y |  |
| SWAP | Y |  |
| THEN | Y |  |
| U. | Y |  |
| U< | Y |  |
| UM\* | Y |  |
| UM/MOD | N | Division with a 64-bit dividend is not supported |
| UNLOOP | Y |  |
| UNTIL | Y |  |
| VARIABLE | Y |  |
| WHILE | Y |  |
| WORD | Y |  |
| XOR | Y |  |
| [ | Y |  |
| [‘] | Y |  |
| [CHAR] | Y |  |
| ] | Y |  |

### 6.3.2 CORE EXTENSION words

|  |  |  |
| --- | --- | --- |
| .( | Y |  |
| .R | Y |  |
| 0<> | Y |  |
| 0> | Y |  |
| <> | Y |  |
| ?DO | Y |  |
| AGAIN | Y |  |
| BUFFER: | Y | Allocates space in PSDRAM. Suitable for larger data blocks |
| C” | Y | In the interpretation state C” will copy the text until the following “ to the PAD as a counted string and return its address |
| CASE | Y |  |
| COMPILE, | Y |  |
| DEFER | Y |  |
| ENDCASE | Y |  |
| ENDOF | Y |  |
| FALSE | Y | Returns 0 |
| HEX | Y |  |
| INTERPRET | Y | Interpret a line from the input buffer |
| IS | Y |  |
| MARKER | Y |  |
| NIP | Y |  |
| OF | Y |  |
| PAD | Y |  |
| PARSE | Y |  |
| PICK | Y |  |
| RESTORE-INPUT | Y | SAVE-INPUT and RESTORE-INPUT use internal variables to store the input source specification. RESTORE-INPUT does not return a flag |
| SAVE-INPUT | Y | See RESTORE-INPUT |
| TRUE | Y |  |
| U.R | Y |  |
| U> | Y |  |
| UNUSED | Y |  |
| WITHIN | Y |  |
| \ | Y |  |

### 6.3.3 FACILITY words

|  |  |  |
| --- | --- | --- |
| KEY? | Y | See also KKEY?, S0KEY? And S1KEY? |

### 6.3.4 FILE ACCESS words

|  |  |  |
| --- | --- | --- |
| INCLUDED | Y |  |

### 6.3.5 PROGRAMMING TOOLS words

|  |  |  |
| --- | --- | --- |
| .S | Y |  |
| ? | Y |  |
| DUMP | Y |  |
| WORDS | Y |  |
| STATE | Y |  |

### 6.3.6 STRING words

|  |  |  |
| --- | --- | --- |
| COMPARE | Y |  |
| SLITERAL | Y | See also CLITERAL |

### 6.3.7 N.I.G.E. Machine specific FORTH words

#### General screen control

|  |  |  |
| --- | --- | --- |
| TAB | ( -- addr) | VARIABLE pointing to the current size of tab stops. The default is 3 |
| ACOL | ( -- addr) | Byte length VARIABLE pointing to the color code for user input keystrokes |
| BCOL | ( -- addr) | Byte length VARIABLE pointing to the color code for output from the FORTH environment |
| TCOL | ( -- addr) | Byte length VARIABLE pointing to the color code for current output by VEMIT or CSR-PLOT |
| CLS | ( --) | Clear the screen |
| COLOR-TABLE | ( --) | Display a table of the 256 available character/text colors |

#### Programming the text/character display

|  |  |  |
| --- | --- | --- |
| VEMIT | ( n --) | Emit a character to the VDU |
| VTYPE | ( c-addr n --) | Type a string to the VDU |
| CSR-X | ( -- addr) | VARIABLE pointing to the current column position of the cursor |
| CSR-Y | ( -- addr) | VARIABLE pointing to the current row position of the cursor |
| CSR-ADDR | ( -- addr) | Return the memory address of the current cursor position within the character/text buffer in PSDRAM |
| CSR-PLOT | ( x --) | Plot the ASCII character x at the current cursor position |
| CSR-ON | ( --) | Plot the cursor symbol at the current cursor position. The character at that position is saved in an internal variable |
| CSR-OFF | ( --) | Unplot the cursor symbol from the current cursor position and restore the character which was previously there |
| CSR-FWD | ( --) | Advance the cursor by one character |
| CSR-BACK | ( --) | Move back the cursor by one character |
| CSR-TAB | ( --) | Advance the cursor to the next tab stop |
| SCROLL | ( n -- flag) | Scroll the screen fwd or back n lines within the 120 line frame buffer. Returns true if out of range, or false otherwise |
| NEWLINE | ( --) | Scroll the screen downwards by one line of text and return the cursor to the first column of the blank line below |

#### External I/O

|  |  |  |
| --- | --- | --- |
| **Word** | **Stack effect** | **Description** |
| S0EMIT | ( x --) | Emit a character to RS232 port 0 |
| S0KEY? | ( -- flag) | Check if a character is waiting to be read from the 256 byte circular buffer maintained for RS232 port 0 |
| S0KEY | ( -- n) | Wait for and read the next character available at RS232 port 0 |
| S0TYPE | ( c-addr n --) | Type a string to RS232 port 0, asynchronous. |
| S1EMIT | ( x --) | Emit a character to RS232 port 1 |
| S1KEY? | ( -- flag) | Check if a character is waiting to be read from the 256 byte circular buffer maintained for RS232 port 1 |
| S1KEY | ( -- n) | Wait for and read the next character available at RS232 port 1 |
| S1TYPE | ( c-addr n --) | Type a string to RS232 port 1, asynchronous. |
| S1ZERO | ( --) | Reset the 256 byte circular buffer maintained for RS232 port 1 and abandon characters currently waiting to be read from there |
| KKEY? | ( -- flag) | Check if a character is waiting to be read from the 256 byte circular buffer maintained for the PS/2 keyboard |
| KKEY | ( -- n) | Wait for and read the next character available from the PS/2 keyboard |
| PS2DECODE | ( n -- n) | Decode a PS/2 scan code into ASCII. Returns 0 if there is no valid ASCII match. PS2DECODE is called directly by the PS/2 interrupt controller. |

#### I/O redirection

|  |  |  |
| --- | --- | --- |
| >REMOTE | ( --) | Redirect FORTH environment output to RS232 port 0 |
| >LOCAL | ( --) | Redirect FORTH environment output to the screen |
| <REMOTE | ( --) | Receive FORTH environment input from RS232 port 0 |
| <LOCAL | ( --) | Receive FORTH environment input from the keyboard |

#### Compiler extensions

|  |  |  |
| --- | --- | --- |
| HERE1 | ( -- addr) | VARIABLE pointing to the dictionary pointer for the PSDRAM dictionary space. Only used by BUFFER: |
| INLINESIZE | ( -- addr) | VARIABLE pointing to the maximum code-length in bytes that the compiler will compile inline rather than as a subroutine call. The default value is 10 and the minimum allowable is 9 since certain code, such as LOOP code, much be compiled inline |
| W, | (w -- ) | Allocate 2 bytes in the dictionary and store a word from the stack |
| M, | (addr u --) | Allocate and store u bytes from addr into the dictionary. u is not saved in the dictionary. Compiles a string or other block of data from memory |
| $, | ( addr u --) | Allocate and store u bytes from addr into the dictionary. u is is compiled as the first byte. Compiles a counted string. |
| LITERAL | ( n --) | Compile a literal to the dictionary |
| CLITERAL | ( addr u --) | Compile to the dictionary a string literal as an executable that will be re-presented at run time as a counted string c-addr |

#### Other common FORTH words

|  |  |  |
| --- | --- | --- |
| BINARY | ( --) | Set BASE = 2 |
| WAIT | ( u --) | Wait for u milliseconds |
| RESET | ( --) | Reset the N.I.G.E. Machine to power on configuration but otherwise preserve memory contents |
| NOT | ( n – n) | Equivalent to 0= |
| XBYTE | ( n – n) | Sign extend a byte on the stack to 32 bits |
| XWORD | ( n –n) | Sign extend a word on the stack to 32 bits |
| W@ | ( addr – n) | Fetch a word from memory |
| W! | ( n addr --) | Store a word in memory |
| FILL.W | ( addr n w --) | Fill a region of memory with n words w. FILL.W utilizes the STORE.W machine language instruction and will be faster than FILL in accessing PSDRAM |
| UPPER | (x -- X) | Convert one ASCII character to uppercase |
| DIGIT | ( char base -- n true | char false ) | Convert a single ASCII character to a number in the given base |
| NUMBER? | ( c-addr u - false | n true ,) | Convert an ASCII string to a number and return with a success or failure flag |
| COMP | ( n1 n2 – n) | Return -1 if n1<n2, +1 if n1>2, 0 if n1=n2 |
| $= | ( c-addr1 u1 c-addr2 u2 -- flag) | Test two strings for equality. Case insensitive. |
| ERROR | ( n --) | Print “ERROR n” and ABORT |

#### SD card reader/writer

|  |  |  |
| --- | --- | --- |
| LOAD | ( c-addr n -- len true | false) | Load a file with the name given by c-addr n into the file buffer from an SD card reader/writer attached to RS232 port 1 |
| SAVE | (c-addr n) | Save the file currently in the file buffer to an SD card reader/writer attached to RS232 port 1 with the name given by c-addr n |
| DOS | ( --) | Enter terminal mode for direct communication with an SD card reader/writer attached to RS232 port 1. Exit terminal mode by pressing ESC |

# 8. System memory map

The memory configuration of the N.I.G.E. Machine is as follows

## 8.1 Overall memory structure

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Address (Hex)** | **Address (Dec)** | **Bytes** | **Type** | **Description** |
| **0000** | **0** | **49152** | FPGA SRAM | System memory |
| **F800** | **63488** | **32** | FPGA logic elements | Hardware registers |
| **010000** | **65536** | **~16MB** | External PSDRAM | System memory |

## 8.2 System memory in SRAM

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Address (Hex)** | **Address (Dec)** | **Bytes** | **R/W** | **Description** |
| **0000** | **0** | **45056** | R/W | FORTH dictionary area (i.e. program and data memory) |
| **B000** | **45056** | **12288** | *-* | *not used* |
| **E000** | **57344** | **2048** | R/W | Parameter stack addressable by CPU |
| **E800** | **59392** | **2048** | R/W | Return stack addressable by CPU |

## 8.3 hardware registers

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Address (Hex)** | **Address (Dec)** | **Bytes** | **R/W** | **Description** |
| **F800** | **63488** | **4** | R/W | Pointer to the character/text graphics buffer in PSDRAM |
| **F804** | **63492** | **4** | R/W | Pointer to the pixel graphics buffer in PSDRAM |
| **F808** | **63496** | **1** | R/W | Background color displayed in mode 1 |
| **F809** | **63497** | **1** | R/W | Video mode |
| **F80A** | **63498** | **1** | R | RS232 port 0 data in |
| **F80B** | **63499** | **1** | W | RS232 port 0 data out |
| **F80C** | **63500** | **2** | R/W | RS232 port 0 UBRR |
| **F80E** | **63502** | **1** | R | RS232 port 1 data in |
| **F80F** | **63503** | **1** | W | RS232 port 1 data out |
| **F810** | **63504** | **2** | R/W | RS232 port 1 UBRR |
| **F812** | **63506** | **1** | R | RS232 status signals |
| **F813** | **63507** | **1** | R | PS2 port data in |
| **F814** | **63508** | **4** | R | 32-bit free running clock counter at 50MHz |
| **F818** | **63512** | **4** | R | 32-bit free running millisecond counter |
| **F81C** | **63516** | **2** | R/W | IRQ mask for interrupt controller |
| **F81E** | **63518** | **2** | W | Nexys II board seven segment display |
| **F821** | **63520** | **1** | R | Nexys II board switches |
| **F823** | **63521** | **2016** | *-* | *not used* |

## 8.4 System memory in PSDRAM

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Address (Hex)** | **Address (Dec)** | **Bytes** | **R/W** | **Description** |
| **010000** | **65536** | **256** | R/W | RS232 port 0 buffer used by interrupt handler |
| **010100** | **65792** | **256** | R/W | RS232 port 1 buffer used by interrupt handler |
| **010200** | **66048** | **256** | R/W | PS2 buffer used by interrupt handler |
| **010300** | **66304** | **256** | R/W | FORTH input message buffer |
| **010400** | **66560** | **256** | R/W | FORTH parse buffer |
| **010500** | **66816** | **256** | R/W | FORTH PAD (low area) |
| **010600** | **67072** | **256** | R/W | FORTH PAD (high area) |
| **010700** | **67328** | **19200** | R/W | Text/character graphics frame buffer |
| **015200** | **86528** | **307200** | R/W | Pixel graphics frame buffer |
| **060200** | **393728** | **65536** | R/W | FORTH SD-card file buffer |
| **070200** | **459264** | **16317951** | R/W | Additional data memory allocated by FORTH BUFFER: |

# 9. Statistics and measurements

## 9.1 FPGA overall utilization

|  |  |  |  |
| --- | --- | --- | --- |
| **Resource** | **Used** | **Available** | **Utilization** |
| 4-input LUT’s | 3,884 | 17,344 | 22% |
| Slice flip flops | 2,920 | 17,344 | 16% |
| 2K block RAM | 28 | 28 | 100% |
| Multipliers | 8 | 28 | 28% |

## 9.2 FPGA module level utilization

|  |  |
| --- | --- |
| **Resource** | **LUT’s** |
| CPU | 2,529 |
| of which datapath | 1,920 |
| of which control unit | 609 |
| DMA controller | 364 |
| Hardware registers | 280 |
| Video controller | 114 |
| Diligent IO port | 95 |
| RS232 controller | 71 |
| Reset controller | 52 |
| PS/2 controller | 39 |
| System RAM | 33 |
| Interrupt controller | 31 |

## 9.3 FPGA timing summary

|  |  |
| --- | --- |
| Maximum frequency | 50.140 MHz |
| Minimum period | 19.944 ns |
| Minimum input required time before clock | 11.507 ns |
| Minimum output required time after clock | 13.097 ns |

## 9.4 Instruction frequency

The 80% most used CPU instructions in the FORTH system software (as counted by the cross-assembler and ignoring loops and conditional code, etc.) are as listed below.

|  |  |
| --- | --- |
| **Instruction** | **Frequency** |
| LOAD.W | 17.88% |
| JSR | 9.17% |
| RTS and ,RTS | 9.06% |
| LOAD.B | 6.47% |
| BEQ | 4.60% |
| DUP | 4.17% |
| OVER | 3.67% |
| FETCH.L | 3.56% |
| DROP | 3.42% |
| STORE.L | 3.02% |
| SWAP | 2.91% |
| R> | 2.37% |
| BRA | 2.37% |
| FALSE | 2.23% |
| FETCH.B | 2.19% |
| 1+ | 2.05% |

\* Of which RTS 6.36% and ,RTS 2.70%

The results illustrate the load-store architecture (LOAD.W is the most used instruction), and the subroutine threaded nature of FORTH (JSR and RTS are the second and third most used instructions).

# 10. Design decisions

This section attempts to communicate the rational for some of the major design decisions in the N.I.G.E. Machine by sharing some of the original design notes as they were made at the time. To provide a clearer view of the design process, the notes have not been adjusted in retrospect.

**Memory access: Pipeline program memory in SRAM only. Data in SRAM and S(D)RAM**

|  |  |
| --- | --- |
| **Equivalent access to SRAM and (S)DRAM through DMA controller** | **Pipeline program memory in SRAM only. Data in SRAM and S(D)RAM** |
| CPU access all RAM through a standard DMA control interface with handshaking | Pipeline scheme takes advantage of guaranteed 1 cycle access in SRAM. Flexible data access |
| Advantages:   * All memory can be used for program memory. Largest program memory space * Reliable design does not need to switch modes for different memory types * No need to differentiate RAM type on data access | Advantages:   * Fastest possible one cycle per instruction execution * Faster 16 or 32 bit (S)DRAM access for data * Further optimizations are likely with independent program and data memory access in SRAM * Reliable design does not need to switch modes for different memory types * Flexible data memory access likely best suited to FORTH implementation |
| Implementation problems:   * CPU needs to implement request/ready memory hand shaking throughout | Implementation problems:   * Need separate FETCH and STORE execution for SRAM and (S)DRAM   + Three sets: SRAM (8 bit), SDRAM(8bit) and SDRAM(16bit), later DRAM(32 bit)   + SDRAM states utilize handshake   + Use common instructions for all cases and split logic flow based on memory location   + Cannot “inc” on first cycle for DRAM, but include in microcode and override this |
|  | |
| **Pipeline access SRAM and DMA access (S)DRAM** | **Pipeline program memory in SRAM only. Data in S(D)RAM** |
| CPU access automatically switches between pipeline access in SRAM and DMA access in (S)DRAM | Full Harvard architecture. |
| Advantages:   * Best of all worlds | Advantages:   * Fastest possible one cycle per instruction execution * Faster 16 or 32 bit (S)DRAM access for data * Further optimizations are likely with independent program and data memory throughout * Reliable design does not need to switch modes for different memory types * No need to implement different FETCH and STORE instructions |
| Implementation problems:   * May not ultimately be feasible since the state machine of the control unit has different requirements in pipeline and handshake modes (PC +1 vs. PC at any given instruction) * Ensuring reliability when crossing memory boundaries likely to be tricky | Implementation problems:   * Pure Harvard architecture cannot support a FORTH interpreter/complier since these need to interrogate as well as execute the FORTH dictionary |

**Interrupt processing: Sequential**

|  |  |
| --- | --- |
| **Sequential** | **Nested hierarchical** |
| Advantages:   * Straightforward logic and programming * May be better to divert LE resources from a complex interrupt unit to bespoke system peripherals on a FPGA core | Advantages:   * Most sophisticated and flexible * Fastest interrupt response times |
| Implementation problems:   * Simple priority encoder * Two state FSM and register to store pending interrupt requests | Implementation problems:   * Supervisor stack required to hold nested interrupt information |

**Cell width: 32 bit**

|  |  |
| --- | --- |
| **32 bit** | **16 bit** |
| Advantages:   * Compatible with main memory address bus width * Faster 32 bit computations * Reduced usage of 2DUP, etc. so can implement these in software | Advantages:   * Compatible with main memory data bus width * Smaller overall FORTH size * Lower LE cost |
| Implementation problems:   * 32 bit fetch and store will require microcode steps | Implementation problems:   * Memory paging will be required |

**Stack implementation:** **small register set plus dedicated dual ported RAM block**

|  |  |
| --- | --- |
| **Large register set** | **Small resister set plus dedicated dual ported RAM block** |
|  | TOS, NOS held in registers, remainder of stack in a dedicated 2K RAM block. Pointer to 3OS (always available) incremented from element zero. Similar for return stack decrementing from top element |
| Advantages:   * Likely most simple implementation of stack manipulation operations * Slightly lower RAM usage | Advantages:   * Much lower LE count * Elegant solution with block RAM |
| Implementation problems:   * On demand memory push/pull system required | Implementation problems:   * Scheme need to prevent stack over/under flow |

**CPU: microcode**

|  |  |
| --- | --- |
| **Hardwired** | **Microcode** |
| Advantages:   * Fastest possible CPU clock speed * Instructions execute in one clock cycle | Advantages:   * Most flexible for implementing as many instructions in hardware as possible * Maybe only feasible way to deal with hardware divide * Smaller instructions and variable length encoding reduce slow memory traffic |
| Implementation problems:   * FSM may be needed anyway for memory access | Implementation problems:   * Will need to include a decoder in the CPU |

**Instruction format: variable 8 – 32 bit**

|  |  |
| --- | --- |
| **Fixed 16 bit** | **Variable 8 – 32 bit** |
| Advantages:   * ‘RISC’ like design smaller and faster at CPU level | Advantages:   * Optimum for code size * Faster at memory access level for SDRAM * Likely implement more FORTH instructions in hardware |
| Implementation problems:   * Direct loads likely need to be byte-at-a-time * Branches may be limited to 14 or 15 bits * JSR (32 bit) will have to be implemented via a previous direct load to the TOS | Implementation problems:   * Variable advancement of program counter |

**Memory scheme: contiguous SRAM and SDRAM**

|  |  |
| --- | --- |
| **Contiguous SRAM and SDRAM** | **SRAM as cache for SDRAM** |
| Arrange address lines so that SRAM appears in the low page of total 16MB memory space. Expect approx 54KB available. Use Port A for CPU and Port B for char RAM, IO DMA, sprite access. (MemSet and other custom chips will be confined to SDRAM using a 2K buffer for burst reads and writes) |  |
| Advantages:   * Fastest possible execution of core code * Can use .COE file for initialization of soft ROM * Minimal LE requirements | Advantages   * Vanilla interface to all RAM from CPU * May have better overall execution speed |
| Implementation problems:   * CPU address logic will need to separate SRAM and SDRAM access in different FSM’s | Implementation problems:   * Will require substantial LE for cache controller * Cache controller likely complex |

# 10. References and acknowledgements

1. **J1: a small Forth CPU Core** **for FPGAs** by James Bowman

The N.I.G.E. Machine instruction set encoding; especially the format for branches and compound RTS instructions is directly inspired by the J1.

1. **Circuit Design and Simulation with VHDL** by Pedroni, 2nd Edition

Concise and very practical guide for learning VHDL

1. **Digital Logic and Microprocessor Design with VHDL** by Enoch O. Hwang

Thorough guide to digital logic and the principals of microprocessors

1. **Stack Computers: the new wave** by Philip J. Koopman, <http://www.ece.cmu.edu/~koopman/>

Explanation of the theory and practice of stack computers

1. **Starting FORTH** by Leo Brodie, <http://www.forth.com/starting-forth>

Standard reference for learning FORTH

1. **Forth Programmer's Handbook** by Elizabeth D. Rather and Edward K. Conklin

Standard textbook on ANSI FORTH

1. **pForth** by Phil Burk, <http://www.softsynth.com/pforth/>

Public domain FORTH implementation that greatly assisted the development of N.I.G.E. Machine FORTH

1. **Programming FORTH** by Stephen Pelc  
   An introduction to modern FORTH systems
2. **Practical and theoretical aspects of FORTH software development** by Peter J. Knaggs

PhD thesis looking in particular at FORTH optimizations

1. **Natmai team**, Gunnar von Boehn and Jens Künzer

Serious experts in softcore design and VHDL who helped me lean how to develop in VHDL